C语言结构题大小计算#include <stdio.h>struct s1{ char c1; // 1 int i; // 4 char c2; // 1};int main()

  • Post author:
  • Post category:其他


一、记住以下四条计算准则

①:第一个成员在与结构体变量偏移量为0的地址处。

②:其他成员变量要对齐到某个数字(对齐数)的整数倍的地址处。对齐数=编译器默认的一个对齐数与该成员大小的较小值,在VS环境下默认值为8,在Linux环境下默认值为4。

③:结构体的总大小为最大对齐数(每个成员变量都有一个对齐数)的整数倍。

④:如果嵌套了结构体的情况,被嵌套的结构体对齐到其自身对齐数的整数倍处(结构体的对齐数就是其内部成员中最大的对齐数),此时结构体的整体大小就是所有最大对齐数(含被嵌套结构体的对齐数)的整数倍。

注:约定为32位系统,即char 1字节、short 2字节、int 4字节,指针是地址4个字节

二、举例子

#include <stdio.h>
struct s1
{
	char c1; // 1
	int i;   // 4
	char c2; // 1

};
int main()
{
	struct s1 s1;
	printf("%d\n", sizeof(s1));
}

结果是12

c1是第一个成员,在偏移量位0的地方占一个字节,用红色的方框表示,i是第二个成员,对齐数是4(对齐数 = 编译器默认的一个对齐数 与 该成员大小的较小值。vs默认对齐数是8,int大小4个字节),所以i要对齐到4的整数倍处,偏移量4的位值,占4个字节的大小,用橙色的4个方框表示,现在偏移量已经到达8,最后一个成员是c2,对齐数是1,任何正整数都是1的倍数,所以c2从偏移量位8的位置开始占1个字节,再处理完后发现一共只有9个字节,这与结果还是不一样,这时就需要用到规则3(结构体总大小为最大对齐数(每个成员变量都有一个对齐数)的整数倍。),上述结构体的最大对齐数位4,而此时已经有9个字节,9显然不是4的倍数,浪费掉一个字节,依次类推,发现12是4的倍数**,12就是结构体的总大小**



版权声明:本文为m0_48064834原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。