};
我个人的理解的对齐 要满足2点
(1) 每个元素的起始位置要能被其大小(字节数)整除
(2) 总体大小要能被最大的元素大小整除
那么第一个
int a :[0..3]
short b :[4..5]
int c 起点要能被4整除 所以是[8..11]
char d [12..13]
一共[0..14]是15个byte
总体要设置为最大(int) 4的倍数 所以应该占16 byte
第二个
double a : [0..7]
short b : [8..9]
int c 起点要能被4整除[12..15]
char d [16,17]
一个 [0..17]是18个byte
总体要设置为最大(double) 8的倍数, 所以应该占24 byte
例子:
#include "stdio.h" struct A { int a; short b; int c; char d; }; struct B { double a; short b; int c; char d; }; int main() { struct A a; struct B b; printf("%d\n",sizeof(a)); printf("%d\n",sizeof(b)); getchar(); return 0; }结果是:
16
24
原文:http://blog.csdn.net/abc5382334/article/details/44901245