C++面试题之结构体内存对齐计算问题总结大全
发布时间:2020-12-31 04:30:48 所属栏目:经验 来源:网络整理
导读:前言 本文给大家介绍的是关于C++结构体内存对齐计算的相关内容,内存对齐计算可谓是笔试题的必考题,但是如何按照计算原则算出正确答案一开始也不是很容易的事,所以专门通过例子来复习下关于结构体内存对齐的计算问题。话不多说,来一起看看详细介绍吧。 编
整体计算过程如下 struct B { char e[2]; //长度1 < 8 按2对齐;偏移量为0;存放位置区间[0,1] short h; //长度2 < 8 按2对齐;偏移量为2;存放位置区间[2,3] //结构体内部最大元素为double,偏移量为4,提升到8,所以从8开始存放接下来的struct A struct A { int a; //长度4 < 8 按4对齐;偏移量为8;存放位置区间[8,11] double b; //长度8 = 8 按8对齐;偏移量为12,提升到16;存放位置区间16,23] float c; //长度4 < 8,按4对齐;偏移量为24,存放位置区间[24,27] }; //整体对齐系数 = min((max(int,double,float),8) = 8,将内存大小由28补齐到8的整数倍32 }; 图示如下: 小结:当#pragma pack的n值等于或超过所有数据成员长度的时候,这个n值的大小将不产生任何效果。 总结 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对编程小技巧的支持。 (编辑:威海站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |