结构体(Struct)

结构体的内存分配

假设这台机器 sizeof(char) = 1 sizeof(int) = 4 sizeof(double) = 8
Struct中各个成员对齐遵循以下原则:

  1. 结构体每个成员相对于结构体首地址的偏移量(offset)都是(这个)成员大小的整数倍,如有需要编译器会在成员之间加上填充字节(internal adding)。
  2. 结构体的总大小为结构体最宽基本类型成员大小的整数倍,如有需要编译器会在最末一个成员之后加上填充字节(trailing padding)。
  3. 还有一个额外的条件:结构体变量的首地址能够被其最宽基本类型成员的大小所整除。
    4.对于结构体成员属性中包含结构体变量的复合型结构体再确定最宽基本类型成员时,应当包括复合类型成员的子成员(子结构体的宽度为子结构体最大的成员)。但在确定复合类型成员的偏移位置时则是将复合类型作为整体看待。
    例子1:
struct MyStruct {
     int a;          //4个字节 
     char b;      //1个字节
     int c;         //4个字节              
     char d;     //1个字节
}
sizeof(mystruct) =  16;
a:偏移0, 大小4, 0是4的整数倍;  分配4个字节
b:  偏移4, 大小1; 分配1个字节
c:  偏移5, 大小4,5不是3的整数倍所以需要在C的前面补3个字节; 分配3 + 4=7个字节
d:  偏移4+1+3+4=12,大小1; 分配12 + 1=13个字节
13不是4(最大成员的占用的字节数)的整数倍,所以需要在最后一个成员后面补3位。即总共分配 13 + 3 = 16字节

例子2:

struct MyStruct {
     int a;          //4个字节 
     char b;      //1个字节
     int c;         //4个字节              
     char d;     //1个字节
};
struct MyPreventStruct {
     int a;          //4个字节 
     char b;      //1个字节
     struct MyStruct myStruct;
};
sizeof(MyStruct) =  16; (见例子1)
sizeof(MyPreventStruct) =  24;
a:偏移0, 大小4, 0是4的整数倍;  分配4个字节
b:  偏移4, 大小1; 分配1个字节
myStruct: 偏移5, 大小16, 偏移5不是大小4(MyStruct中最宽的元素)的整数倍,所以需要在前面补3位。 分配 11+16=27个字节。
总大小=4 + 1 + 3 + 16 = 24;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 结构体 在C语言中,可以使用结构体(Struct)来存放一组不同类型的数据。结构体的定义形式为: 结构体是一种集合...
    Xiho丶阅读 1,054评论 0 2
  • 内存对齐的三大原则: 1>如果结构体里面的成员变量都是基本数据类型(int,char,float,double,指...
    踩在浪花上00阅读 425评论 0 0
  • @[c++|struct] 今天在编程中碰到一个坑,搞的调试了半天,最后发现程序中在写数据和读取数据时结构体定义不...
    drybeans阅读 3,634评论 1 11
  • 引言 C语言结构体内存布局是一个老生常谈的问题,网上也看了一些资料,有些说的比较模糊,有些是错误的。本人借鉴了前人...
    boborz阅读 1,068评论 0 2
  • 本篇文章转自David的"The empty struct"一文,原文地址链接是http://dave.chene...
    Zuozuohao阅读 3,384评论 0 3