结构体空间的大小计算

本文深入解析了C++中pragma pack指令的使用,包括其对结构体成员对齐方式的影响,以及如何通过调整pack值来优化内存布局。通过具体实例,详细解释了如何在VC6.0环境中利用此特性来调整结构体的内存分配,包括成员变量的位置调整和空间填充策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#pragma  设置编译器的属性;

pack(1) 对齐方式的属性;按照个字节1对齐;

#pragma pack(1)里面的数字是1,2, 4,8,16 其他的就是默认的方式8;

pack(2)如果比结构体中最大的类型还大。如#pragma pack(16)那么忽略最大类型,按默认8的进行分配空间;

下面再举个例子,交换一下上面的MyStruct的成员变量的位置,使它变成下面的情况:

  struct MyStruct 
  { 
  	char dda; 
  	double dda1;   
  	int type 
  };

#pragma pack(1)=13
#pragma pack(2)=14
#pragma pack(4)=16
#pragma pack(8)=24
#pragma pack(16)=24
这个结构占用的空间为多大呢?在VC6.0环境下,可以得到sizeof(MyStruc)为24。结合上面提到的分配空间的一些原则,
  分析下VC怎么样为上面的结构分配空间的。(简单说明)
  struct MyStruct 
  { 
  char dda;//偏移量为1,满足对齐方式sizof(char),dda占用个字节1;
  double dda1;//下一个可用的地址的偏移量为1,不是sizeof(double)=8 的倍数,需要补足7个字节才能使偏移量变为(满足对齐方式),因此VC自动填充7个字节,dda1存放在偏移量为8的地址上,它占用8个字节。
  int type;//下一个可用的地址的偏移量为16,是sizeof(int)=4的倍数,满足int的对齐方式,所以不需要VC自动填充,type存放在偏移量为20的地址上,它占用4个字节。
  };
所有成员变量都分配了空间,空间总的大小为+7+8+4=20,不是结构的节边界数(即结构中占用最大空间的类型所占用的字节数sizeof (double)=8)的倍数,所以需要填充个字节,以满足结构的大小为sizeof(double)=8的倍数。
所以该结构总的大小为:sizeof(MyStruc)为+7+8+4+4=24。
其中总的有7+4=11个字节是VC自动填充的,没有放任何有意义的东西。



### C/C++ 中嵌套结构体的总大小计算 当处理嵌套结构体时,编译器会遵循特定规则来确保数据按照适当的方式对齐。对于给定的例子 `struct s2` 和更复杂的嵌套情况: #### 基本概念回顾 - **内存对齐**:为了提高CPU访问效率,在某些架构下,不同类型的数据需要存储在特定边界上[^2]。 - **最大对齐数**:指结构体内各成员中最大的自然对齐值。 #### 单一结构体示例分析 考虑如下简单结构体: ```c++ struct s2 { char ch1; int i; char ch2; }; ``` 此结构体的实际占用空间并非仅仅是三个字段之和(即 1 + 4 + 1 字节),而是考虑到字节填充后的最终尺寸为8字节[^1]。 #### 复杂嵌套结构体案例解析 假设有一个更为复杂的情形,其中包含另一个结构体作为成员之一,则整体布局将更加微妙。例如: ```c++ // 定义内部结构体 struct InnerStruct { short a; // 2 bytes, alignment requirement is 2 }; // 定义外部结构体并嵌入上述内层结构体 struct OuterStruct { char b; // 1 byte, alignment requirement is 1 double c; // 8 bytes, alignment requirement is 8 (largest among all members) InnerStruct d; // sizeof(InnerStruct)=2 due to padding after 'a' // but must be aligned according to the largest member inside it or itself. }; ``` 在此情况下,`OuterStruct` 的实际大小取决于几个因素: - 各个独立成员自身的长度及其所需的最小对齐单位; - 内部子结构体 `InnerStruct` 需要被放置在一个能够满足其最严格对齐需求的位置上; - 整个外层对象也需要保证可以按需分配足够的额外空白区域以实现正确的结尾对齐。 具体来说,由于 `double` 类型的存在使得整个 `OuterStruct` 至少要有8字节的对齐度;而 `InnerStruct` 虽然本身只需要两字节的空间加上可能的一字节填充用于保持短整型变量 `short a` 正确排列,但在 `OuterStruct` 内它同样受到后者的影响从而占据更多连续地址区间直至达到下一个合适的起始位置。 因此,经过合理安排之后,`sizeof(OuterStruct)` 可能远大于各个组成部分相加的结果,并且确切数值依赖于具体的平台特性以及编译选项设置等因素影响下的默认或自定义对齐策略。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值