结构体的空间开辟及字节对齐
结构体空间的开辟,和与字节对齐之间是有联系的。
关于结构体的字节对齐就是,编译器在编译阶段,会为结构体的每个成员变量按照其自然边界分配存储空间。各成员按照他们被声明的顺序在内存中顺序存储,第一个成员的地址和整个结构体的起始地址相同。
通过代码来验证一下(32bit)
如图,在结构体中定义了一个先定义了一个char类型的变量,再定义了一个short类型的变量,char类型在内存中占1个字节,而short类型在内存中占2个字节,总共是3个字节,而系统开辟了四个字节的空间。再看一个例子:
结果是12,这是因为结构体的大小一定要为有效对齐值的整数倍。在这个代码中,补齐了char ch和char ch01的字节。如果定义多个不同变量呢?变量的顺序会不会影响空间的开辟呢?如:
通过上面我们可以分析出,这里开辟的空间确实是8个字节,但实际上只用了7个字节,这个时候我们再定义一个char类型的变量,刚好是1个字节,那么这一个字节会不会自动补齐变成8个字节呢?答案是NO,我们来看一下代码:
这就是因为在结构体里开辟空间时,找成员里占用空间最大的成员,以它的空间作为开辟的最小单位,填充按基本单位1,2,4进行填充。
仔细想想,上面这个代码中,char ch01的定义如果定义在int 前,是不是会更节省空间呢?在这里可以优化一下。
总结:关于字节开辟,哪个基本类型的成员占字节数多, 就以它的大小为单位开辟内存。结构体的大小一定要为有效对齐值的整数倍。在定义变量成员时时,尽量按照占空间的大小,由小到大进行定义。
指定对齐
宏#pragma pack (N)指定的值,#pragma pack(2):设置结构体的边界对齐为2个字节,其存储时连续的但是处理大数据效率偏低,速度慢。