什么是内存对齐
typedef struct{
int a; //a占4个字节 0~3
double b; //b占8个字节 8~15
short c; //c占2个字节 16~17
}A;
内存对齐,对齐规则是按照成员的声明顺序,依次安排内存,其偏移量为成员大小的整数倍,0看作任何成员的整数倍,最后结构体的大小为最大成员的整数倍。
sizeof(A)=8+8+8=24而不是8+8+2=18
typedef struct{
int a; //a占4个字节 0~3
short b; //b占2个字节 4~5
double c; //c占8个字节 8~15
}B;
sizeof(B)=4+4+8=16
为什么要内存对齐?
1、平台原因(移植原因):不是所有的硬件平台都能随意访问任意地址上的任意数据;某些硬件平台只能在某些地址处取某些特定类型的数据,否则抛出硬件异常。
2、性能原因:数据结构(尤其是栈)应该尽可能地在自然边界上对齐,原因在于,为了访问未对齐的内存,处理器需要做两次内存访问;而对齐的内存访问仅需要一次访问。