先说结论:sizeof求得的结构体的大小并不一定等于各个数据成员的大小之和。
struct
比如有如上两个结构体:A和B。都含有两个int型,一个double型数据成员,但成员的顺序不一样。
如上图所示,int 和 double 分别为4个字节和8个字节。而结构体A和B使用sizeof的结果分别为16个字节和24个字节。
可以看出结构体B所占的字节数并不等于其成员之和:
sizeof(B) ≠ sizeof(int) + sizeof(double) + sizeof(int)
之所以出现这样的结果,就是因为编译器要对结构体的数据成员在空间上进行字节对齐。
一、什么是字节对齐
现代计算机中,内存空间是按照字节划分的,理论上可以从任意起始地址访问任意类型的变量。但在实际中,访问特定类型变量时经常在特定的内存地址,这就需要各种数据类型按照一定的规则在空间上排列,而不是一个接一个地顺序存放。这就是所说的字节对齐。
字节对齐主要针对的就是结构体。
二、为什么需要字节对齐
字节对齐的一个原因是:各个硬件平台对某些特定类型的数据只能从某些特定地址开始存取。比如有些架构的CPU在访问一个没有进