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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值