python struct.pack中的对齐字节问题

转自
https://www.cnblogs.com/xywq/p/4898373.html最近测试涉及到了序列字节化相关问题,碰到一个头疼的问题

buff = struct.pack(“3s”,“B00”)
print repr(buff)

输出:‘B00’

buff = struct.pack(‘i’,10172)
print repr(buff)

输出:"\xbc’\x00\x00"

buff = struct.pack(“3si”,“B00”,10172)
print repr(buff)

输出:“B00\x00\xbc’\x00\x00”

即:struct.pack(“3s”,“B00”)+struct.pack(‘i’,10172) != struct.pack(“3si”,“B00”,10172)

但struct.pack("!3s",“B00”)+struct.pack(’!i’,10172) == struct.pack("!3si",“B00”,10172)是相等的

问题分析:

为了同c中的结构体交换数据,还要考虑有的c或c++编译器使用了字节对齐,通常是以4个字节为单位的32位系统,故而struct根据本地机器字节顺序转换.可以用格式中的第一个字符来改变对齐方式.定义如下:

Character Byte order Size and alignment
@ native native 凑够4个字节
= native standard 按原字节数
< little-endian standard 按原字节数

big-endian standard 按原字节数
! network (= big-endian)
standard 按原字节数

使用方法是放在fmt的第一个位置,就像’@5s6sif’

参见如下

http://www.coder4.com/archives/3838

http://www.cnblogs.com/gala/archive/2011/09/22/2184801.html

http://zhidao.baidu.com/link?url=Wd7SipMBMz7-lCTtnV3kUmjF4OMlRqZZUtfY0Zb3SqF5HKsCbwUBJFw8s2FfpTTv55Y-o-YHctDEfJoQ_ILTYAM8-sOWvOPS4aJtlHffNZ_

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值