标签:opened gif while bytearray debug 十进制 ati play bool
甲方使用的后台要求“整型数据采用小端传输”,大部分数据是4字节十六进制,有一些是2字节十六进制。
关于大小端传输,简单来说可以这样认为。
内存中低地址存最低有效字节的形式为小端传输
内存中低地址存最高有效字节的形式为大端传输
例如一个4字节十六进制数"0x11223344",装入QByteArray中。
如果取出结果如下
buff[0] == 0x44;
buff[1] == 0x33;
buff[2] == 0x22;
buff[1] == 0x11;
这里的"0"就表示低地址,0x44表示最低有效位。
Qt中关于大小端数据也有封装好的接口,头文件qendian.h或者QtEndian。
主要记录一下进制之间的转换
1 const quint32 i = 1010; 2 QString hex = QString("%1").arg(i, 8, 16, QLatin1Char(‘0‘)); 3 qDebug() << "hex " << hex; 4 bool ok; 5 qDebug() << hex.toInt(&ok, 16); 6 7 //十进制转十六进制 8 QByteArray buffer; 9 buffer[0] = (i & 0xff); 10 buffer[1] = ((i >> 8) & 0xff); 11 buffer[2] = ((i >> 16) & 0xff); 12 buffer[3] = ((i >> 24) & 0xff); 13 14 //十六进制转回十进制数 15 quint32 x = (buffer[0] & 0x000000ff) 16 | ((buffer[1] << 8 )& 0x0000ff00) 17 | ((buffer[2] << 16)& 0x00ff0000) 18 | ((buffer[3] << 24)& 0xff000000); 19 qDebug() << "x" << x; 20 int c = 0; 21 22 //十六进制转string 23 QString et; 24 while(c < 4){ 25 QString str =QString("%1").arg(buffer[c]&0xFF,2,16,QLatin1Char(‘0‘)); //2 字符宽度 26 et += str; 27 c++; 28 } 29 qDebug() << "et " << et; 30 qDebug() << et.toInt(&ok, 16); 31 qDebug() <<"ok" << ok ; 32 33 //返回小端数据接口使用 34 uchar *ptr = new uchar[4]; 35 qToLittleEndian(i,ptr); 36 int c = 0; 37 while(c < 4){ 38 buffer.append(ptr[c]); 39 c++; 40 } 41 42 qToLittleEndian(i, ptr); 43 //qbswap<quint32>(i, ptr); 44 45 qDebug("%02x,%p",ptr[0],&ptr[0]); 46 qDebug("%02x,%p",ptr[1],&ptr[1]); 47 qDebug("%02x,%p",ptr[2],&ptr[2]); 48 qDebug("%02x,%p",ptr[3],&ptr[3]);
标签:opened gif while bytearray debug 十进制 ati play bool
原文地址:https://www.cnblogs.com/warmSnowFY/p/10525446.html