1、字节对齐是为了提高效率,因为因为硬件平台的不同,数据总线可能从特定地址读取数据。
总大小:
结构体的大小等于最后一个成员的偏移量加上其大小再加上末尾的填充字节数目,即:
sizeof( struct ) = offsetof( last item ) + sizeof( last item ) +sizeof( trailing padding )
2、原则
1、按数据类型自身地址对齐(理解:结构体每个成员相对于结构体首地址的偏移量(offset)都是(这个)成员大小的整数倍)
2、整个结构体所占内存是成员变量中占 内存最大的变量的 整数倍
3、举例子
注意,变量的顺序不同,可能所占的空间也不一样。
为了是内存所占空间得到优化,最好把占空间大的变量放在前面。
4、之前的疑惑
之前我总不明白为什么要把两个char型的变量放在一起,尤其是第二个char变量,明明不是在4的整数倍上。
原因:我之前以为每个变量的地址都要是结构体变量中所占内存最大的变量的整数倍,发现理解错了。 是每个变量按自身类型对齐,如char为1对齐,int为4对齐,double为8对齐,但是结构体所占内存的总和要是占 内存 最大变量的整数倍,不足的要补空位。
参考:https://stackoverflow.com/questions/20737176/how-are-struct-members-allocated-in-memory
参考:http://www.cnblogs.com/qintangtao/archive/2013/03/06/2945674.html