7.c++-内存对齐的一点个人理解(#pragma pack(k))
来源:互联网 发布:python的ide哪个好 编辑:程序博客网 时间:2024/05/23 01:15
1.默认的#pragma pack(k)中k的大小是多少?
vc下默认是8。
2.什么叫偏移值?
偏移值是相对于数据存储的首地址而言的,首地址的偏移值自然为0,首地址后一位的偏移值自然为1。
2.结构体(结构体不内嵌子结构体)内存对齐原则是什么?
#pragma pack(k),
(1).对于结构的各个成员,第一个成员位于偏移为0的位置(也就是首地址开始),以后每个数据成员的偏移值必须是min(k,这个数据成员的自身长度(设为len))的倍数,明白点说,如果len小于K,起始位置的偏移值为len倍数,如果大于k,起始位置的偏移值为len倍数。
(2).在(1)完成后,如果得到的的总大小为sum,sum必须是min(k,成员中最大的len)的整数值,不足则补足,如sum为15,min(k,len)=4,则sum补足为16。
例子:
struct A{ char c1; short s; char c2; int i;};
c1起始于首地址(a0),占1个字节(a0),s本应起始于(a1),由(1)知起始位偏移量必须为min(8,2)的倍数,所以起始于(a2),占2个字节(a2,a3),c2本应起始于(a4),由(1)知起始位偏移量必须为min(8,1)的倍数,所以仍起始于(a4),占一个字节(a4),i本应起始于(a5),由(1)知起始位偏移量必须为min(8,4)的倍数,所以起始于(a8),占4个字节(a8,a9,a10,a11),所以大小为a0 X|a2 a3|a4 X X X|a8 a9 a10 a11为12。
3.结构体(结构体内嵌子结构体)内存对齐原则是什么?
(1).用2的方法计算子结构体的大小
(2).用2的方法计算本结构体的大小,对于2中(1)提到的偏移量是min(k,子结构体成员中最大的len)的倍数。
(2).如果得到的的总大小为sum,sum必须是min(k,成员中最大的len)的整数值,对子结构体变量而言,只提供子结构体成员中最大的len用来比较.而不是整个大小。
例子:
struct A{char c1;short s;char c2;double i;};struct foo{char c1;A a ;};
用2可知A的大小为16,对于foo中c1起始于首地址(a0),占一个字节(a0),a本应起始于(a1),由min(k,子结构体成员中最大的len)=8知,a起始于(a8),占16个字节(a8..a15),sum为24,是min(k,8)的倍数,注意,这里a提供的是它的结构体的成员最大len(8),而不是自身大小16。
- 7.c++-内存对齐的一点个人理解(#pragma pack(k))
- 内存对齐与#pragma pack的理解
- 关于#pragma pack()和内存分配的一点理解
- #pragma pack 内存对齐
- 内存对齐及#pragma pack的使用
- 限制内存对齐的 #pragma pack(1)
- 对齐系数 #pragma pack(k)
- 内存对齐(#pragma pack)
- 内存对齐(#pragma pack)
- 内存对齐(#pragma pack)
- 内存对齐(#pragma pack(n))
- (C)字节对齐#pragma pack()
- 关于pragma pack的用法--------------C 中的内存对齐问题(转载)
- 内存对齐----#pragma pack的用法及大小的计算
- 关于pragma pack的用法--------------C++中的内存对齐问题
- 内存中数据对齐(#pragma pack的用法)
- 关于pragma pack的用法 C++中的内存对齐问题
- 关于pragma pack的用法C++中的内存对齐问题
- 预览ExtJS 4.0的新功能(六):读写器/Opeartion
- 英特尔称MeeGo将专注智能手机等四大方面应用
- 消息队列(Message Queue)简介及其使用
- Unpacking Argument Lists
- Xilinx设计元素缩写查询
- 7.c++-内存对齐的一点个人理解(#pragma pack(k))
- MeeGo系统平板电脑和智能手机明年上市
- . Net环境下消息队列(MSMQ)对象的应用
- Update 关联子查询
- Design Pattern - Builder(C#)
- Android-x86 - Porting Android to x86
- 关于WSERV 9 错误的总结!
- Apache+Tomcat+虚拟机整合
- 部署图