struct/class以及union内存对齐四个原则:
1、数据成员对齐规则:结构(struct)(或联合(union))的数据成员,第一个数据成员放在offset为0的地方,以后每个数据成员存储的起始位置要从该成员大小或者成员的子成员大小(只要该成员有子成员,比如说是数组,结构体等)的整数倍开始(比如int在32位机为4字节, 则要从4的整数倍地址开始存储),基本类型不包括struct/class/uinon。
2、结构体作为成员:如果一个结构里有某些结构体成员,则结构体成员要从其内部"最宽基本类型成员"的整数倍地址开始存储.(struct a里存有struct b,b里有char,int ,double等元素,那b应该从8的整数倍开始存储.)。
3、收尾工作:结构体的总大小,也就是sizeof的结果,.必须是其内部最大成员的"最宽基本类型成员"的整数倍.不足的要补齐.(基本类型不包括struct/class/uinon)。
4、sizeof(union),以结构里面size最大元素为union的size,因为在某一时刻,union只有一个成员真正存储于该地址。
测试用例:
- #include <iostream>
- using namespace std;
- union a
- {
- int a_int1;
- double a_double; //8字节
- int a_int2;
- char ch;
- //由原则4,a的大小为8
- };
- struct b
- {
- a a1; //[0]...[7] ,
- char y; //[8]
- //由原则3,"最宽基本类型成员"为a中的double,从而b的大小为8的整数倍,所以b的大小为16
- };
- class c
- {
- int c_double; //[0]...[4]
- b b1; //[7]...[23] 原则2:与b的内部的最大元素的整数倍开始存储
- char ch; //[24]
- //由原则3,"最宽基本类型成员"为b中,即b里面a的double,c的大小为8的整数倍,所以c的大小为32
- };
- struct usc
- {
- char ch; //[0]
- b b2; //[7]...[23] 原则2:与b的内部的最大元素的整数倍开始存储
- a a2; //[24]...[31]
- c c2; //[32]...[63]
- char ch1; //[64]
- //"最宽基本类型成员"为a中的double 或者 即b里面a的double 或者 c里面的b里面的double
- //由原则3,usc的大小为8的整数倍,所以usc的大小为72
- };
- void main()
- {
- cout<<"sizeof(a)= "<<sizeof(a)<<endl;
- cout<<"sizeof(b)= "<<sizeof(b)<<endl;
- cout<<"sizeof(c)= "<<sizeof(c)<<endl;
- cout<<"sizeof(usc)= "<<sizeof(usc)<<endl;
- }
总结:
从“struct/class以及union内存对齐原则”可以得出:在struct/class/union中定义变量时,长度小的变量先定义,长度大的变量后定义,可以节省内存。