如下代码输出多少?
struct A
{
int a;
short b;
int c;
char d;
};
int main()
{
printf("%d\n",sizeof(struct A));
return 0;
}
如果按照正常来看的话,输出为4+2+4+1 = 11
但是运行时却输出了16
为什么会有额外的空间被占用了,可见结构体内部的成员并非连续排放的,这其中的原因在于结构体的对齐问题。
结构体的对其有着以下的规则:
1、结构体的第一个成员默认排第一个,没有占额外的位置。
2、从第二个成员开始,往后的每一个成员都要对齐到某个对齐数的整数倍处。
对齐数:结构体成员自身大小和默认对齐数中的较小值。比如int类型大小为4,vs上默认对齐数为8,则int类型要对齐到4的整数倍处
3、结构体的总大小必须是最大对齐数的整数倍。
根据以上3条规则,我们再看上面的代码,可知大小为4+2+(2 对齐到8)+4+1+(3 补充为4的整数倍)