将字节向量转换为浮点向量

时间:2019-04-19 00:44:14

标签: c++ arrays vector memcpy

我正在通过串行端口将固定长度的字节流发送到另一台计算机,我想尝试将字节流转换为浮点数矢量。

我的流具有定界符stop,并且我正在使用this串行库。

我当前的实现涉及以下内容:

我读了一个字符串

 std::string data_string;
 ser.readline(data_string, 2052, "stop");

检查字符串是否以定界符结尾

 if(boost::algorithm::ends_with(stop_string, "stop"))
    {                
       if(data_string.length() == 2052)

然后将字符串转换为向量

   std::vector<unsigned char>bytes(stop_string.begin(), stop_string.end());

然后我使用for循环和memcpybytes转换为浮点数数组。

     unsigned char temp_buffer[4];
     float float_values[513] = { 0 };
     int j = 0;
     for(size_t i = 4; i < 2052; i+=4)
          {
              temp_buffer[0] = bytes[i - 4];
              temp_buffer[1] = bytes[i - 3];
              temp_buffer[2] = bytes[i - 2];
              temp_buffer[3] = bytes[i - 1];
              memcpy(&float_values[j], temp_buffer, sizeof(float));
              j++;
           }

但是这种方法看起来很麻烦,我想避免for循环。有没有办法:

  • bytes向量转换为浮点数向量吗?

  • 避免for循环吗?

2 个答案:

答案 0 :(得分:2)

浮点数数组和无符号字符向量的字节大小相同。您可以直接从缓冲区中将memcpy放入浮点数组中。

这好像不是您的字节已交换或其他任何内容。您只想将4个连续字节解释为一个浮点数。

这也消除了循环

编辑更新:

如果您使用的是C ++ 11或更高版本,则可以依靠std::string's internal buffer is stored contiguously并直接从中复制的事实。不需要临时字节缓冲区,这样可以为您节省大量内存(半页)。

示例:

// copy directly from string
float float_values[data_string.size()/sizeof(float)]; // 513
std::memcpy(float_values, data_string.data(), data_string.size());

答案 1 :(得分:1)

自从您标记为通用C ++之后,我将使用C ++ 20引入的一些很酷的新功能:)

#include <algorithm>
#include <cstddef>
#include <span>
#include <vector>

std::vector<float> ToFloats(const std::vector<std::byte>& bytes) {
    std::vector<float> floats(bytes.size() / sizeof(float), 0.0f);
    std::copy_n(bytes.begin(), floats.size() * sizeof(float),
                std::as_writable_bytes(std::span(floats)).begin());
    return floats;
}

Live Example   (std::bytestd::spanstd:: as_writable_bytes