C语言结构体大小计算

这篇文章来探讨一下C语言中,结构体占的内存大小如何计算。

	printf("str = %d", sizeof(struct str));//用这个方法来查看一个结构体的大小

我尝试了好几次发现一个奇怪的现象,当定义一个结构体变量的时候,结构体成员的顺序不同就会造成这个结构体所占的空间大小的不同。
这是什么原因呢?原来是因为在编译器中,为了CPU访问数据的高效率。如果变量的地址不对齐,那么CPU读取结构体就需要对结构体成员进行重复的访问,然后组合得到整型数据。而如果变量在自然对齐位置上,则只要一次就可以取出数据。而在有的要求严格的系统中一旦对齐出错,就会导致数据出错。因此字节对齐尤为重要。
那计算机又是如何进行字节对齐的呢?
在不同的编译器中,不同的系统中默认的对齐方式会有所不同。在需要控制对齐的时候可以使用。

#pragma pack(n)//n表示n字节对齐

下面我对vs 2017和Ubuntu的字节对齐方式进行说明。

1、首先是vs2017里面
默认的8字节对齐,也就是说最后字节的大小一定要是8的倍数。
我用代码演示一下。

#include<stdio.h>
#pragma pack(8)
struct str {
	int a;//4
	char b;//4
};

int main()
{
	printf("str = %d", sizeof(struct str));
	return 0;
}

这个结构体的大小是8。 第一个程序的结果图

为什么呢?第一个是int型,占了4位,而char型是1个字节占一位,所以要在后面补3为,和上面加起来是8位。
占位图示意思就是在存入结构体的时候不是按照他本来的大小去存入的,而是说按照一个规律去把这写数据有序的排列起来,让它们在空间里面有序的排放。

下面在给几个例子。。。。

#include<stdio.h>
#pragma pack(8)
struct str {
	char c;//4
	int a;//4
	char b;//4
};

int main()
{
	printf("str = %d", sizeof(struct str));
	return 0;
}

总共是12.

#include<stdio.h>
#pragma pack(8)
struct str {
	char c;//
	char b;//两个char一共是4
	int a;//4
};

int main()
{
	printf("str = %d", sizeof(struct str));
	return 0;
}

总共是8

猜你喜欢

转载自blog.csdn.net/qq_38821783/article/details/86532880