什么是内存补齐?
简言之,就是各种复合数据结构(如 class, struct, union,array 等)依照其最大的成员类型字节数进行补齐。
首先,各数据成员依据自身类型大小分别进行不齐,最后,复合数据结构再根据最大的类型补齐。如下:
struct test
{
char a;
int b;
short c;
double d;
};
sizeof(test) = ?
首先,a为1个字节,其自然对齐码为1, b为4个字节,自然对起码为4, 所以a后面需要填充3个空白字符, 同理,c自然对齐码为2, d为8,
所以,分别填充0个,6个空白字符,再加上d,总共为24个字符,最后,因为test结构中最大的类型为double, 8个字节,故test自然对
齐码为8, 检查24能被8所整除, 所以
sizeof(test) = 24;
其内存结构如下:
1,1111,11***,11111111
默认情况下,编译器一般按8字节大小补齐,各成员补齐时,按照 Min(自身自然对齐码, 默认大小)补齐。
可以通过伪指令#pragma pack (n) 设置默认大小
伪指令#pragma pack () 取消设置
更多参考, 请参见
http://blog.csdn.net/digu/article/details/4768623
原文链接: https://www.cnblogs.com/khalil/archive/2012/10/05/2712389.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/64873
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!