这篇文章来探讨一下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;
}
123456789101112
这个结构体的大小是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;
}
12345678910111213
总共是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;
}
12345678910111213
总共是8