int main(){
struct test
{
char i;
int t;
};
test a;
a.i = 'f';
a.t = 1;
int i = sizeof(a);
printf("%d\n", sizeof(a.i));
printf("%d\n",sizeof(a.t));
printf("%d\n", i);
system("pause");
return 0;
}
运行结果:
1
4
8
#include <stdio.h>
#include <stdlib.h>
struct test
{
char a;
float b;
int c;
double d;
};
int main(){
test t;
int i = sizeof(t);
printf("这个结构体的大小为:%d", i);
return 0;
}
运行结果:
这个结构体的大小为:24
原因:
结构体是一种复合数据类型,通常编译器会自动的进行其成员变量的对齐,已提高数据存取的效率。在默认情况下,编译器为结构体的成员按照自然对齐(natural alignment)条方式分配存储空间,各个成员按照其声明顺序在存储器中顺序存储。
在默认对齐方式下,结构体成员的内存分配满足下面三个条件
1.结构体第一个成员的地址和结构体的首地址相同
2.结构体每个成员地址相对于结构体首地址的偏移量(offset)是该成员大小的整数倍,如果不是则编译器会在成员之间添加填充字节(internal adding)。
3.结构体总的大小要是其成员中最大size的整数倍,如果不是编译器会在其末尾添加填充字节(trailing padding)。
简单来说,struct的大小计算为:其中变量所占大小的最小公倍数(这个数还必须大于所有变量所占大小的和)