C++ 如何在C+中将大/小尾数字节转换为整数,反之亦然+;
我将从带有QTcpSocket的服务器接收以下格式的长度分隔帧:-C++ 如何在C+中将大/小尾数字节转换为整数,反之亦然+;,c++,qt,endianness,C++,Qt,Endianness,我将从带有QTcpSocket的服务器接收以下格式的长度分隔帧:- +----------+--------------------------------+ | len: u32 | frame payload | +----------+--------------------------------+ 其中,u32是以Big-Endian格式编码的32位无符号整数。根据配置的不同,它也可以是Little Endian,但我会在客户端预先了解Endian
+----------+--------------------------------+
| len: u32 | frame payload |
+----------+--------------------------------+
其中,u32是以Big-Endian格式编码的32位无符号整数。根据配置的不同,它也可以是Little Endian,但我会在客户端预先了解Endian
如何将此char*
数组或QByteArray
的前4个字节转换为32位无符号整数
阅读完框架后,我需要以相同的格式发送消息。因此,如果我有长度为20字节的消息,如何将20作为32位无符号整数写入QByteArray或字符*,采用大/小尾端格式?方法是:
bytearray -> stream ->setorder -> serialize to variable
QByteArray newData = ....;
QDataStream stream(newData);
stream.setByteOrder(QDataStream::LittleEndian); // or BigEndian
stream >> variable;
您可以使用Qt的实用函数来实现这一点
例如,如果您有一个quint32
(或uint32\u t
),并希望以小尾端格式将该值写入字符数组的前四个字节:
const quint32 myValue = 12345;
char frameBuffer[256];
qToLittleEndian(myValue, frameBuffer);
。。。或者,以小尾数形式读取字符数组的前四个字节quint32
(或uint32\u t
):
const char帧缓冲区[256]={0x01,0x00,0x00,0x00};
quint32 myValue=qFromLittleEndian(帧缓冲区);
Big-endian的读/写操作与此相同,只需将函数名中的子字符串Little
替换为Big
。FYI:
const char frameBuffer[256] = {0x01, 0x00, 0x00, 0x00};
quint32 myValue = qFromLittleEndian<quint32>(frameBuffer);