struct 的长度对齐

结构体的sizeof的值并不是简单的将其中各个元素所占的字节相加,而是要考虑到存储空间的字节对齐问题

结构体默认的字节对齐准则:

1.           结构体变量的首地址能够被其最宽基本类型成员的大小所整除;

2.           结构体每个成员相对于结构体首地址的偏移量(offset)都是成员大小的整数倍,如有需要编译器会在成员之间加上填充字符;

3.           结构体的总大小为结构体最宽基本类型成员大小和编译器缺省対界条件大小中比较小得那个值的整数倍,如有需要编译器会在最后一个成员之后加上填充字节;

 结构体长度的求法:

A.     成员都相同时(或含数组且数组数据类型同结构体其他成员数据类型)

结构体长度=成员数据类型长度*成员个数;

结构体中数组长度=数组数据类型长度*数组元素个数;

B.     成员不同

第一步: 结构体的首地址有系统自动分配我们不予考虑

第二步:计算第一个成员变量的大小

第三步:计算第二个成员变量的大小,此时要注意此成员变量的偏移量(距离结构体首地址的长度)要保证是此变量大小的整数倍,如果不够则补空位;

依次计算所有成员变量,并求和。

第四步:选出所有成员变量中长度最长的变量的值,此时要保证总和是此变量长度的整数倍。如果不是则在最后面补空位

注意:结构体作为成员时,则结构体成员要从其内部最大元素大小的整数倍地址开始存储。

 

例题一、

struct  test1

{

char a;

int  b;

double c;

bool d;

};

sizeoftest1)值为24

内存结构为 1***  1111  11111111  1*******(其中*为补空位)

例题二、

struct  test2

{

         char a;

         struct test1  bb;

         int  c;

};

sizeof(test2)的值为40

首先求a大小为1,在求bb时我们需要考虑偏移量,此时我们使用的bb的对比值并不是24而是test1中的最长值8,因此在字符a后需要补空位7

然后加上bb长度24

再计算c并加上其长度4.此时一共长36.

最后我们要注意原则中的第三条。在test2中最长的是结构体类型bb中的double,故总长度应该是8的整数倍。所以最后补位4位,得到40

内存结构为 1********  1***  1111  11111111  1******* 1111****(其中*为补空位)

例题三、

Struct test3

{

         Char  a;

         Int b[4];

};

此时计算sizeoftest3)为20

 

内存结构为1***  1111 1111 1111 1111

你可能感兴趣的:(计算机运算)