联合体的特点及其大小的计算

上篇博客,笔者详细的介绍了联合的的使用方法!所以,笔者在这篇文章打算进行:联合体的特点及其大小的计算的讲述!!


联合体的特点:

联合体的成员是共用一块内存空间的,这样一个联合体变量的大小,至少是最大的成员的大小!(因为联合体至少得有能力保存最大的那个成员)!!


下面进入本篇文章的重中之重的部分:联合体大小的计算!!

在进行下面的内容之前,我们需要知道:

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]

union un
{
	short s[7];
	int i;
};

对于该段联合体的分析情况为:上述联合体的大小为:16

 本文到此就结束了!若各位老铁有不懂得地方,请私聊笔者,或者评论区发一评论哟!!

猜你喜欢

转载自blog.csdn.net/weixin_64308540/article/details/127310541