内存对齐概念,struct例子:
struct stu{
char a;
intb;
char c;
double d;
char e;
}
取pack(n),n,取结构体中最大成员大小m,取两个小值k, k = m< n?m:n;
取每个成员大小p,依次同k比较,取小值q = k< p?k:p;
第二步当中依次取得的值,即为内对齐标准,所谓的对齐,即此处的地址可被q整除。
K值可作为外部对齐补0的依据。
当有数组的时候拆散了当普通变量存储。
下面开始计算结构体中的大小
取k值。(取pack(4))
经分析,元素中占空间最大的是double类型的,其占8个字节。所以k = 8 < 4 ? 8:4;所以k = 4;
2、取每个成员大小p依次同k比较,取值q = k<p?k:p;
验证:
从图中可以知,和上面的理论是一致的。