4字节十六进制数据和大小端传输

本文介绍了在处理4字节和2字节十六进制数据传输时,如何遵循小端字节序的要求。讲解了大小端传输的概念,即内存低地址存放最低有效字节为小端,反之为大端。在Qt中,利用qendian.h或QtEndian头文件可以方便地进行大小端转换。此外,文章提到了在2019年新增的内容,涉及使用libz.so库进行数据压缩和解压缩操作,以及如何将单个字符转化为16进制字符串的过程。
摘要由CSDN通过智能技术生成

甲方使用的后台要求“整型数据采用小端传输”,大部分数据是4字节十六进制,有一些是2字节十六进制。

关于大小端传输,简单来说可以这样认为。

内存中低地址存最低有效字节的形式为小端传输

内存中低地址存最高有效字节的形式为大端传输

例如一个4字节十六进制数"0x11223344",装入QByteArray中。

如果取出结果如下

buff[0] == 0x44;

buff[1] == 0x33;

buff[2] == 0x22;

buff[1] == 0x11;

这里的"0"就表示低地址,0x44表示最低有效位。

 

Qt中关于大小端数据也有封装好的接口,头文件qendian.h或者QtEndian

主要记录一下进制之间的转换

 1     int c=254254;
 2     QByteArray data((char*)&c,4);
 3     QByteArray data0=intToByte(c);
 4     QByteArray data1=QByteArray::fromHex(QString::number(c,16).toLatin1());
 5     qDebug()<<data.toHex()<<data.toHex().toInt(NULL,16)<<data.mid(0,1).toHex()<<data.mid(1,1).toHex()<<data.mid(2,1).toHex()<<data.mid(3,1).toHex();
 6     qDebug()<<data0.toHex()<<bytesToInt(data0);
 7     qDebug()<<data1.toHex()<<data1.toHex().toInt(NULL,
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值