C++ 如何在C+中将大/小尾数字节转换为整数,反之亦然+;

C++ 如何在C+中将大/小尾数字节转换为整数,反之亦然+;,c++,qt,endianness,C++,Qt,Endianness,我将从带有QTcpSocket的服务器接收以下格式的长度分隔帧:- +----------+--------------------------------+ | len: u32 | frame payload | +----------+--------------------------------+ 其中,u32是以Big-Endian格式编码的32位无符号整数。根据配置的不同,它也可以是Little Endian,但我会在客户端预先了解Endian

我将从带有QTcpSocket的服务器接收以下格式的长度分隔帧:-

+----------+--------------------------------+
| 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);