简介
在C++中,将uint64_t转换为小端字节序的QByteArray并指定长度,需通过手动字节分解+填充/截断实现。
核心代码实现
#include<QCoreApplication>#include<QByteArray>#include<QDebug>#include<cstdint>QByteArrayuint64ToQByteArrayLittleEndian(uint64_tvalue,inttargetLength,charpadChar='\0',Qt::Alignment padAlign=Qt::AlignRight){QByteArray bytes;bytes.resize(8);// 初始化为8字节(uint64_t的原始长度)// 手动按小端序分解uint64_t为字节bytes[0]=static_cast<char>(value&0xFF);// 最低有效字节(LSB)bytes[1]=static_cast<char>((value>>8)&0xFF);bytes[2]=static_cast<char>((value>>16)&0xFF);bytes[3]=static_cast<char>((value>>24)&0xFF);bytes[4]=static_cast<char>((value>>32)&0xFF);bytes[5]=static_cast<char>((value>>40)&0xFF);bytes[6]=static_cast<char>((value>>48)&0xFF);bytes[7]=static_cast<char>((value>>56)&0xFF);// 最高有效字节(MSB)constintcurrentLength=bytes.length();// 处理长度不足的情况if(currentLength<targetLength){constintpaddingNeeded=targetLength-currentLength;QByteArraypadding(paddingNeeded,padChar);if(padAlign==Qt::AlignRight){bytes.append(padding);// 末尾填充}elseif(padAlign==Qt::AlignLeft){bytes.prepend(padding);// 开头填充}else{qWarning()<<"Invalid alignment, defaulting to AlignRight";bytes.append(padding);}}// 处理长度超过的情况elseif(currentLength>targetLength){qWarning()<<"Truncating result to target length";bytes=bytes.left(targetLength);}returnbytes;}intmain(intargc,char*argv[]){QCoreApplicationa(argc,argv);uint64_ttestValue=0x123456789ABCDEF0;// 测试1: 目标长度10,末尾补零QByteArray result1=uint64ToQByteArrayLittleEndian(testValue,10);qDebug()<<"Result 1 (end padding):"<<result1.toHex();// 测试2: 目标长度10,开头补零QByteArray result2=uint64ToQByteArrayLittleEndian(testValue,10,'\0',Qt::AlignLeft);qDebug()<<"Result 2 (start padding):"<<result2.toHex();// 测试3: 目标长度6,截断处理QByteArray result3=uint64ToQByteArrayLittleEndian(testValue,6);qDebug()<<"Result 3 (truncated):"<<result3.toHex();returna.exec();}关键逻辑解析
- 小端序分解:
uint64_t的最低有效字节(LSB)存储在bytes[0],最高有效字节(MSB)存储在bytes[7]。
通过位操作(如value & 0xFF和移位)逐字节提取,确保小端序。 - 长度处理:
填充:若目标长度大于8字节,在开头或末尾填充指定字符(如\0)。
截断:若目标长度小于8字节,保留前targetLength字节(可能破坏数据,需谨慎)。
系统字节序无关性:
代码手动控制字节顺序,与系统实际字节序无关。即使系统是大端,也能生成小端序的QByteArray。
测试用例输出
- 测试1(末尾补零):
原始数据:F0 DE BC 9A 78 56 34 12(小端序)
目标长度10 → 末尾补2个零:F0 DE BC 9A 78 56 34 12 00 00 - 测试2(开头补零):
目标长度10 → 开头补2个零:00 00 F0 DE BC 9A 78 56 34 12 - 测试3(截断):
目标长度6 → 保留前6字节:F0 DE BC 9A 78 56
注意
截断风险:截断可能导致数据丢失或解析错误,需确保目标长度合理。
填充字符:根据协议或场景选择填充字符(如零、空格或自定义值)。
跨平台兼容性:手动字节分解确保代码在任何系统字节序下行为一致。
通过此实现,可灵活控制uint64_t到QByteArray的小端序转换及长度调整,满足网络传输、文件存储等场景需求。