在我正在研究的c ++解决方案中,我有一个返回字符串引用的函数。像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*
也不起作用。
使用向量,您正在编写的是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 ++书。
更新:因为你的评论似乎你有一个编译时常量最大大小,我添加了一个真正的数组版本:
#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;
};