在我的程序中,我使用串行通信进行了大量工作,因此经常使用QByteArray
。
我想知道是否有一种更短的方法来初始化具有特定字节的QByteArray
:
const char test_data[] = {
static_cast<char>(0xB1), static_cast<char>(0xB2),
0x5, static_cast<char>(0xFF),
static_cast<char>(0xEE), static_cast<char>(0xEE),
static_cast<char>(0x0)}; // Note QByteArray should be able to hold 0 byte
const QCanBusFrame frame = QCanBusFrame(0xA1, QByteArray(test_data));
static_cast<char>
是必要的,因为否则C ++ 11会出现关于缩小的错误,因为范围0x7F到0xFF大于char
可能适合的范围 - 但是char
是QByteArray
构造函数要求的内容。
这是使用的QByteArray
构造函数:
QByteArray::QByteArray(const char *data, int size = -1)
答案 0 :(得分:23)
简单有效:
QByteArray b = QByteArrayLiteral("\x12\x00\xa4\x42\x51\x00\x00\x99");
答案 1 :(得分:4)
作为QByteArrayLiteral
的替代方案,如果您愿意,可以自行滚动:
#include <QByteArray>
template <int N> QByteArray arrayFromLiteral(const char (&data)[N]) {
return QByteArray::fromRawData(data, N-1);
}
int main() {
const auto arr = arrayFromLiteral("\xB1\xB2\0\1");
Q_ASSERT(arr.size() == 4);
Q_ASSERT(arr[0] == (char)0xB1);
Q_ASSERT(arr[1] == (char)0xB2);
Q_ASSERT(arr[2] == (char)0x00);
Q_ASSERT(arr[3] == (char)0x01);
}
答案 2 :(得分:2)
const unsigned char str[] = {0xff, 0xed, 0xba, 0xd1};
QByteArray ba(reinterpret_cast<const char*>(&str[0]),std::extent<decltype(str)>::value);
现在QByteArray构造函数看起来很奇怪,但是字节序列很清楚。您也可以将终止的0字节添加到数组而不是使用std::extent
,但通常您可以在序列中间使用零字节。
答案 3 :(得分:2)
受到上述答案的启发,我最终提出了这个问题:
const quint8 testData[] {0xB1, 0x00, 0xB2, 0x00};
const QCanBusFrame cFrame = QCanBusFrame(
0xA1, QByteArray(reinterpret_cast<const char*>(testData), sizeof(testData)));
在使用串行通信时,我更喜欢将字节作为字节数而不是文字字符。
在讨论了## c ++之后,我被告知在这种情况下reinterpret_cast
被恰当地使用了。
答案 4 :(得分:2)
可能工作缓慢:
QByteArray ba = QByteArray::fromHex(QVariant("B1B2FFEEEE00").toByteArray());
答案 5 :(得分:0)
您是否尝试过以下操作:
const unsigned char test_data[] = {
static_cast<char>(0xB1), static_cast<char>(0xB2),
0x5, static_cast<char>(0xFF),
static_cast<char>(0xEE), static_cast<char>(0xEE),
static_cast<char>(0xB3)};
const QCanBusFrame frame = QCanBusFrame(0xA1, QByteArray((char*)test_data));
您正在使用构造函数:QByteArray::QByteArray(const char *data, int size = -1)
。
如果size为负数,则假定数据指向以空字符结尾的字符串,并且动态确定其长度。终止空字符不被视为字节数组的一部分。