C++之内存对齐原则(解释+代码演示)

最近准备找实习,写点博客做点笔记。

先上百度原文:

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

发布了29 篇原创文章 · 获赞 29 · 访问量 6774

猜你喜欢

转载自blog.csdn.net/xuanhuangwendao/article/details/104417359