我有一个返回字符串引用的函数。例如const std::string& getData() const {return mData;}
,而mData是std::string mData;
。现在我想将其转换为uint8_t
数组,以将其传递给另一个函数指针。
/* in another header -> typedef uint8_t U8; */
const std::string& d = frame.getData();
U8 char_array[d.length()];
/* here I want to put the d char by char in char_array*/
strcpy
已过时,因此我使用strcpy_s
之类的strcpy_s(char_array, d);
我当然会得到couldn't match type char(&)[_size] against unsigned char[]
,并且对char*
的静态或重新解释强制转换也不起作用。
答案 0 :(得分:2)
使用向量,您正在编写的是VLA,这不是有效的C ++(U8 char_array[d.length()]
)。然后使用std::copy
。
const std::string& d = frame.getData();
std::vector<U8> char_array(d.length() + 1, 0);
问题是,是否需要字符串\0
的结尾,因此,如果要最后一个\0
,它将为d.length()+ 1。然后:
std::copy(std::begin(d), std::end(d), std::begin(char_array));
更新:显然,目标是将此向量存储在另一个uint8_t[8]
中,如果它是一个名为foo
的变量,请执行以下操作:
std::copy(std::begin(d), std::end(d), std::begin(foo));
但是请先检查长度...然后将结构填充为参考。还可以获得一本不错的C ++书。
答案 1 :(得分:0)
更新:由于从您的注释中可以看出,您有一个编译时常数最大大小,因此我添加了一个真实的数组版本:
#include <string>
#include <vector>
#include <cstdint>
#include <algorithm>
#include <iterator>
#include <array>
struct foo {
std::string& getData() {return mData;}
const std::string& getData() const {return mData;}
std::vector<uint8_t> get_array() const {
std::vector<uint8_t> array;
std::copy(mData.cbegin(), mData.cend(), std::back_inserter(array));
return array;
};
static constexpr size_t max_size = 8u;
std::array<uint8_t, max_size> get_max_array() const {
std::array<uint8_t, max_size> array;
std::copy_n(mData.cbegin(), max_size, array.begin());
return array;
}
private:
std::string mData;
};