struct模块模仿C结构。处理器读取奇数地址上的16位字或不被4整除的地址上的32位dword会花费更多的CPU周期,因此结构添加“填充字节”以使结构成员落在自然边界上。考虑:
struct { 11 char a; 012345678901 short b; ------------ char c; axbbcxxxdddd int d;};
此结构将占用12个字节的内存(x为填充字节)。
Python的工作方式与此类似(请参见struct文档):
>>> import struct>>> struct.pack('BHBL',1,2,3,4)'x01x00x02x00x03x00x00x00x04x00x00x00'>>> struct.calcsize('BHBL')12
编译器通常可以消除填充。在Python中,任何= <>!将消除填充:
>>> struct.calcsize('=BHBL')8>>> struct.pack('=BHBL',1,2,3,4)'x01x02x00x03x04x00x00x00'
当心让结构处理填充。在C中,这些结构:
struct A { struct B { short a; int a; char b; char b;}; };
通常分别为4和8个字节。如果在阵列中使用结构,则填充发生在结构的末端。这将使“
a”成员在数组的后面结构的正确边界上对齐。Python的struct模块不会在末尾填充:
>>> struct.pack('LB',1,2)'x01x00x00x00x02'>>> struct.pack('LBLB',1,2,3,4)'x01x00x00x00x02x00x00x00x03x00x00x00x04'
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)