计算结构体的大小:
结构体中可以定义的数据类型:
1.基本类型
2.上面已经出现过的数据类型,比如说上面已经定义过的结构体
3.指向自己的指针
因为内存对齐的问题,各个数据类型放的位置不同就会导致结构体的大小不一样,那么到底
怎样计算一个结构体的大小呢?
先介绍一个概念——偏移量,结构体中的偏移量就是结构体成员和结构体变量的地址之差,
比如说第一个结构体成员的偏移量就是0,第二个结构成员的偏移量就是第一个结构体成员
的大小,假如第一个成员的是int b;那么第二个结构体成员变量的偏移量就是4,
计算结构体大小的规则:
1.每一个成员的偏移量都必须是该成员的倍数。
2.结构体的大小必须是该结构体字节数最大成员的倍数。
例如下面的结构体:例一:
struct A { char a; short b; int c; };
第一个成员的偏移量都是0;一般可以不看,a的大小为1,所以成员b的偏移量为1,b的大小
为2,1不是2的倍数,所以应该将1+1,成为2的倍数,成员c的偏移量就为1+1+2,是成员c的
倍数,现在就符合计算结构体大小的第一条:改成员的偏移量是该成员大小
的倍数,还有第二条规则:结构体大小是结构体最大成员的倍数,结构体的大小就是各个成员
之和,a;2,b:2,c:4加起来就是8,该结构最大成员为c大小为4,满足第二个条件,所以该结
构体的倍数就是8
代码:
#include <stdio.h> int main () { struct A { char a; short b; int c; }; printf ("%d",sizeof(A)); return 0; }
例二:
struct Data { char a; int b; int64_t c; 该数据类型是有符号的占64位的整形数据类型 char d; }
成员a的偏移量就不用看了,上面有说每一个结构体第一个成员的偏移量都为0;
但他的大小是1,也就是成员b的偏移量,成员b的大小是4,1不是4的倍数,所以a
的大小1应该加上3,就是4,成员3的偏移量是8,成员c的大小是8,成员c的偏移量是
成员c大小的倍数,就不用增加大小,成员d的偏移量是16,成员d的大小是1,偏移量
是成员大小的倍数,现在就符合计算结构体大小的第一条:改成员的偏移量是该成员大小
的倍数,还有第二条规则:结构体大小是结构体最大成员的倍数,最大成员为c,大小
是8,结构体的大小就是各个成员之和,a:4,b:4,c:8,d:1所有的加起来就是17,
但是17不是8的倍数,所以应该将17+7就是24,所以该结构体的大小就是24
代码:
#include <stdio.h> int main () { struct Data { char a; int b; long long c; char d; }; printf ("%d\n",sizeof(Data)); return 0; }