最近准备找实习,写点博客做点笔记。
先上百度原文:
1、数据成员对齐规则:结构(struct)(或联合(union))的数据成员,第一个数据成员放在offset为0的地方,以后每个数据成员的对齐按照#pragma pack指定的数值和这个数据成员自身长度中,比较小的那个进行。
2、结构(或联合)的整体对齐规则:在数据成员完成各自对齐之后,结构(或联合)本身也要进行对齐,对齐将按照#pragma pack指定的数值和结构(或联合)最大数据成员长度中,比较小的那个进行。
实际就是酱:
struct Node {
char a;//0...1 规则1
char c;//1...2
int b;//4...8
char d;//8...9
double f;//16...24
int e;//24...28
//28...32 规则2 ,最大的8的倍数
};
如果加上#pragma
先试试对齐系数为1,这样的话其实就相当于各元素紧挨着。。。
#pragma pack(1)
其实就是1+1+4+1+8+4=19
再试试2
#pragma pack(2)
结果:
struct Node {
char a;//0...1 规则1
char c;//1...2
int b;//2...6
char d;//6...7
double f;//8...16
int e;//16...20
//20...20 规则2 ,最大的2的倍数
};
没毛病b( ̄▽ ̄)d
再试试大于最大成员长度:
#pragma pack(16)
和没改前一样。
如果系数不是2的幂
#pragma pack(3)
可以看到是没有效果的。
总结(对规则的通俗解释)
1、对齐系数 n 必须为2的幂次
2、每一个成员的起点offset是 k*min(n,size) (k∈N)
3、结构体的总大小为 k*min(n,max(size)) (k∈N)
参考资料:
https://baike.baidu.com/item/%E5%86%85%E5%AD%98%E5%AF%B9%E9%BD%90/9537460#2