自定义类型:结构体,枚举,联合
结构体的自引用
正确的自引用方式
struct Node
{
int data;
struct Node* next;
}
结构体变量的内存对齐问题
对其规则
1.第一个成员在与结构体变量偏移量为0的地址处。
2. 其他成员变量要对齐到某个数字(对齐数)的整数倍的地址处。
对齐数 = 编译器默认的一个对齐数 与 该成员大小的较小值。
VS中默认的参照值为8 Linux中的参照值为4
3. 结构体总大小为最大对齐数(每个成员变量都有一个对齐数)的整数倍。
4. 如果嵌套了结构体的情况,嵌套的结构体对齐到自己的最大对齐数的整数倍处,结构体的整体大小就是
所有最大对齐数(含嵌套结构体的对齐数)的整数倍。
总的来说:结构体内存对其是拿空间来换取时间
可以使用#pragma pack() 命令修改默认对齐数
位段
1.位段的成员必须是整型家族的成员
struct A
{
int _a:2;
int _b:5;
int _c:10;
};
2.位段的空间上是按照需要以4个字节或者1个字节的方式来开辟的
3.位段涉及很多不确定因素,位段是不跨平台的,注重可移植的程序应该避免使用位段
枚举
1.枚举类型本质是int,而且默认情况是从0开始依次递增的int
2.枚举是一种类型,在编译的时候会进行类型检查,宏是基于替换原则,在这个过程中,并不进行任何检查工作。
3.宏的应用场景>>枚举
联合体
1.联合体本身的大小并不是把所有的类型加起来的大小
2.常规而言,联合体的大小是由联合体内最大元素的大小决定的。决定了之后,所有元素共享空间
3.在使用union的时候,一次只会访问一个元素
4.联合体也要考虑内存对齐问题
5.联合体的最终大小,要能整除联合体内的最大对齐数