我可以初始化一个QByteArray
像:
QByteArray m_data;
m_data[0] = 0x0c;
m_data[1] = 0x06;
m_data[2] = 0x04;
m_data[3] = 0x04;
m_data[4] = 0x02;
m_data[5] = 0x00;
但我想要更紧凑的东西,比如:
QByteArray m_data{0x0c, 0x06, 0x04, 0x04, 0x02, 0x00};
很遗憾,此表单不允许:
error: could not convert '{12, 6, 4, 4, 2, 0}' from '<brace-enclosed initializer list>' to 'QByteArray'
QByteArray m_data{0x0c, 0x06, 0x04, 0x04, 0x02, 0x00};
^
有没有其他选择(更接近我的梦想)?
(C ++ 11/14/17有助于解决这个问题吗?)
您可以让模板确定列表中有多少元素:
using myarr = char[];
template <size_t N>
QByteArray make_QByteArray(const char(&a)[N]) {
return {a,N};
}
然后创建QByteArray
:
auto m_data{make_QByteArray(myarr{0x0c, 0x06, 0x04, 0x04, 0x02, 0x00})};
我正在寻找这样的答案,但在表达式中包含声明的变量;例如:
char v1 = 0x06, v2 = 0x04;
QByteArray m_data;
m_data[0] = 0x0c; m_data[1] = v1 ; m_data[2] = v2 ;
m_data[3] = v2 ; m_data[4] = 0x02; m_data[5] = 0x00;
//And a character higher than 0x7f
m_data[6] = 0x8b;
这是我发现的解决方案:
char v1 = 0x06, v2 = 0x04;
QByteArray ba(std::begin<char>({0x0c, v1, v2, v2, 0x02, 0x00, '\x8b'}), 7);
使用std::begin甚至std::initializer_list C ++ 11功能都可以实现。