在我的项目中,我正在使用QByteArrays在程序运行时向他们追加数据。大多数情况下,使用quint8
可以很好地添加一个简单的QByteArray::append()
。但是当附加quint16
时,只会附加1个字节而不是2个。
QByteArray ba = QByteArray::fromHex("010203");
quint number(300);//300 in hex is 012c
ba.append(number);//What should be appended instead of just number?
//the current incorrect result is
ba.toHex() == "0102032c"
//the desired result is
ba.toHex() == "010203012c"
我已经尝试过这个,但它只是将值作为字符串插入(4个字节):
ba.append(QByteArray::number(number, 16));
我应该将什么附加到QByteArray,以便" number"得到附加而不只是一个字节?此外,最好的方法是首选,因为该程序需要有很长的性能时间。所以绝对没有转换到QStrings。
感谢您的时间。
答案 0 :(得分:6)
就其本身而言,QByteArray
仅支持附加字节;要附加固定大小整数类型的大端表示,您可以使用适当的位移构建自己的operator<<
(或您喜欢的)重载:
QByteArray &operator<<(QByteArray &l, quint8 r)
{
l.append(r);
return l;
}
QByteArray &operator<<(QByteArray &l, quint16 r)
{
return l<<quint8(r>>8)<<quint8(r);
}
QByteArray &operator<<(QByteArray &l, quint32 r)
{
return l<<quint16(r>>16)<<quint16(r);
}
这允许您编写如下代码:
QByteArray b;
b<<quint16(300); // appends 0x01 0x2c
b<<quint8(4); // appends 0x04
b<<quint16(4); // appends 0x00 0x04
b<<quint32(123456); // appends 0x00 0x01 0xe2 0x40
b<<quint8(1)<<quin16(2)<<quint32(3); // appends 0x01 0x00 0x02 0x00 0x00 0x00 0x03
你应该避免写
QByteArray b;
b<<1;
因为理论上输出取决于当前平台整数的大小(尽管Qt int
支持的所有平台上的AFAIK都是32位)。