上篇博客,笔者详细的介绍了联合的的使用方法!所以,笔者在这篇文章打算进行:联合体的特点及其大小的计算的讲述!!
联合体的特点:
联合体的成员是共用一块内存空间的,这样一个联合体变量的大小,至少是最大的成员的大小!(因为联合体至少得有能力保存最大的那个成员)!!
下面进入本篇文章的重中之重的部分:联合体大小的计算!!
在进行下面的内容之前,我们需要知道:
1.联合体的大小至少是最大成员的大小!!
2.当最大成员的大小不是最大对齐数的整数倍的时候,就要对齐到最大对齐数的整数倍!
3.联合体的大小,不一定总是最大成员的大小!
下面请看笔者代码部分:
#include <stdio.h> union un { char arr[5]; //5个字节 int i; //4个字节 }; int main() { printf("%d\n", sizeof(union un)); return 0; }
对于这个代码,该联合体成员的大小一个为5,一个为4,但是最后运行出来的结果却为:8!!这个又是为什么呢??
对联合体的内容进行分析:
因此,上面再内存中的分配情况为:
笔者在借用几个联合体的代码,来带领大家分析一下:
1.
union un { short s[6]; int i; };
对于该段联合体的分析情况为:
在这里,我们需要铭记的是:最大成员的大小是:最大对齐数的整数倍!!
2.将上面的数组short s[6]更改为:short s[7]
x
union un { short s[6]; int i; };
对于该段联合体的分析情况为:上述联合体的大小为:16
本文到此就结束了!若各位老铁有不懂得地方,请私聊笔者,或者评论区发一评论哟!!