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

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


联合体的特点:

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


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

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

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

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

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

念君思宁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值