传说中的字节对齐呀
在计算机中,为了加快寻址速度,把宽度为4的数据位于能被4带除的地址上,宽度为8的数据都为于能被8整除的地址上……
在结构体中,整个结构体所点的字节数应为其成员中宽度最大的数据的整数倍。结构体每个成员所处地址的偏移量都是该成员大小的整数倍。以上两点如果不满足则会以填充字节来补齐。
LZ所给的b中,最大数据成员为double,8个字节,所以整个结构体的字节数应为8的整数倍,但后面的char只一个字节,所以在char后面全有七个字节的填充位,以补充够16个字节。
同时c也要进行字节对齐,所以是32字节
[[it] 本帖最后由 kyln 于 2008-4-23 19:45 编辑 [/it]]
在计算机中,为了加快寻址速度,把宽度为4的数据位于能被4带除的地址上,宽度为8的数据都为于能被8整除的地址上……
在结构体中,整个结构体所点的字节数应为其成员中宽度最大的数据的整数倍。结构体每个成员所处地址的偏移量都是该成员大小的整数倍。以上两点如果不满足则会以填充字节来补齐。
LZ所给的b中,最大数据成员为double,8个字节,所以整个结构体的字节数应为8的整数倍,但后面的char只一个字节,所以在char后面全有七个字节的填充位,以补充够16个字节。
同时c也要进行字节对齐,所以是32字节
[[it] 本帖最后由 kyln 于 2008-4-23 19:45 编辑 [/it]]