C++内存对齐规则
来源:互联网 发布:java获取webapp下路径 编辑:程序博客网 时间:2024/05/21 19:28
C++内存对齐规则
每个特定平台上的编译器都有自己的默认“对齐系数”(也叫对齐模数)。程序员可以通过预编译命令#pragma pack(n),n=1,2,4,8,16来改变这一系数,其中的n就是你要指定的“对齐系数”。
对齐规则:
1、数据成员对齐规则:结构(struct)(或联合(union))的数据成员,第一个数据成员放在offset为0的地方,以后每个数据成员的对齐按照 #pragma pack指定的数值和这个数据成员自身长度中,比较小的那个进行。//MIN(#pragma pack,sizeof(type))
2、结构(或联合)的整体对齐规则:在数据成员完成各自对齐之后,结构(或联合)本身也要进行对齐,对齐将按照#pragma pack指定的数值和结构(或联合)最大数据成员长度中,比较小的那个进行。MIN(#pragma pack,Max(#pragma pack,sizeof(type)))
3、结合1、2推断:当#pragma pack的n值等于或超过所有数据成员长度的时候,这个n值的大小将不产生任何效果。
4.各成员变量存放的起始地址相对于结构的起始地址的偏移量必须为该变量的类型所占用的字节数的倍数。
5.各成员变量在存放的时候根据在结构中出现的顺序依次申请空间,同时按照上面的对齐方式调整位置,空缺的字节自动填充。
6.同时为了确保结构的大小为结构的字节边界数(即该结构中占用最大空间的类型所占用的字节数)的倍数,所以在为最后一个成员变量申请空间后,还会根据需要自动填充空缺的字节。
每个特定平台上的编译器都有自己的默认“对齐系数”(也叫对齐模数)。程序员可以通过预编译命令#pragma pack(n),n=1,2,4,8,16来改变这一系数,其中的n就是你要指定的“对齐系数”。
对齐规则:
1、数据成员对齐规则:结构(struct)(或联合(union))的数据成员,第一个数据成员放在offset为0的地方,以后每个数据成员的对齐按照 #pragma pack指定的数值和这个数据成员自身长度中,比较小的那个进行。//MIN(#pragma pack,sizeof(type))
2、结构(或联合)的整体对齐规则:在数据成员完成各自对齐之后,结构(或联合)本身也要进行对齐,对齐将按照#pragma pack指定的数值和结构(或联合)最大数据成员长度中,比较小的那个进行。MIN(#pragma pack,Max(#pragma pack,sizeof(type)))
3、结合1、2推断:当#pragma pack的n值等于或超过所有数据成员长度的时候,这个n值的大小将不产生任何效果。
4.各成员变量存放的起始地址相对于结构的起始地址的偏移量必须为该变量的类型所占用的字节数的倍数。
5.各成员变量在存放的时候根据在结构中出现的顺序依次申请空间,同时按照上面的对齐方式调整位置,空缺的字节自动填充。
6.同时为了确保结构的大小为结构的字节边界数(即该结构中占用最大空间的类型所占用的字节数)的倍数,所以在为最后一个成员变量申请空间后,还会根据需要自动填充空缺的字节。
阅读全文
0 0
- C内存对齐规则
- C/C++ 内存对齐规则
- C语言中内存对齐规则讨论
- C/C++—— 内存字节对齐规则
- 内存对齐规则
- 内存对齐规则
- 内存对齐规则
- struct 内存对齐规则
- 内存对齐规则
- 内存对齐规则
- 内存对齐规则
- 内存对齐的规则
- 内存对齐规则
- C++内存对齐规则
- C语言中内存对齐规则讨论(struct)
- C语言中内存对齐规则讨论(struct)
- C语言中内存对齐规则讨论(struct)
- c/c++对齐规则
- 创建对象的几种方法的总结
- 数素数 (20)
- Hadoop2.7.3 mapreduce(四)倒排索引的实现
- PHP基础教程-01 PHP概述
- Spring思维导图,让Spring不再难懂(mvc篇)
- C++内存对齐规则
- E. One-Way Reform
- 栈的压入、弹出序列
- R中read.csv第一行报错
- R的Parallel包学习
- UVa439---Knight Moves(BFS应用)
- 剑指offer-孩子们的游戏(圆圈中最后剩下的数)
- HDU5688 Problem D【字符串排序+MAP】
- 解析xml 几种方法