C语言中结构体内存对齐

先写一个小程序:
#include<stdio.h>
struct student 
  int a;
  char k;
  short m;
};
int main()
{
struct student pp={45,'a',1};
short *m=(short *)((int)&pp+6);     // 偏移量+6
printf("m=%d.\n",*m);
printf("sizeof(pp)=%d.\n",sizeof(struct student));
return 0;
}
 
测出结构体的大小为8
输出*m=1;
由此可以看出数据如何在内存中存储的。
 
int型4字节 ,char型 1字节,short型2字节。
应该为7字节,由于内存对齐 8字节。char 型数据存完后的空间1字节被填充了,short 在第7,8字节里存储。(这是编译器自己做的)

  1)结构体每个成员相对结构体首地址的偏移量(offset)是对齐参数的整数倍,如有需要会在成员之间填充字节。编译器在为结构体成员开辟空间时,首先检查预开辟空间的地址相对于结构体首地址的偏移量是否为对齐参数的整数倍,若是,则存放该成员;若不是,则填充若干字节,以达到整数倍的要求。

  2)结构体变量所占空间的大小是对齐参数大小的整数倍。如有需要会在最后一个成员末尾填充若干字节使得所占空间大小是对齐参数大小的整数倍。

猜你喜欢

转载自www.cnblogs.com/947033916-fwh/p/9863207.html