结构体的大小到底该如何加计算
首先我们看一个例子
#include<bits/stdc++.h>
using namespace std;
typedef struct Alen
{
int a;
char b;
double c;
Alen* p;
};
int main()
{
Alen m;
printf("%d", sizeof(m));
return 0;
}
在这个例子中 , 结构体由四个部分组成, 分别是4字节的 int, 1字节的char, 8字节的double, 和8字节的指针变量
按照我们的认知这个Alen 的大小应该是 4 + 1 + 8 +8=21 B
但是这个最后的结果确实 24B.
至于为什么会出现这样的情况我们要了解x86的内存对齐规则
- 起始地址是基本数据类型的倍数
- 整个结构体的大小数最大数据类型的倍数
根据这个规则我们画出内存图
在给char分配空间的时候,本来应该分配1B ,但是下一个类型是double,起始地址应该是8的倍数,因此我们需要补齐3个B