联合union的赋值机制

这个知识点出现在我的期末试卷上,由于当时对这个概念掌握的不清楚,3分没了。。找了很多其他的博客,这一方面的解释很少,所以在这里写一篇吧,可能自己解释的也不算清楚全面,所以请各位读者只是当做一个参考吧。
我们都知道联合(也叫共用体)中的不同类型的变量都是放在同一个地址开始的内存单元里面,当然这个内存单元足够大以至于可以容下所占空间最大的那个数据类型。当给联合中的某一个数据类型赋值时,会改变其他数据类型的值,但是联合中最后保存的数据一定就是最后向其中的某一个变量赋的值么?我们先来看下面这个代码。

#include <stdio.h>
union u{
	int a;	
	int b;
};
int main()
{
	union u t;
	t.a=100;
	t.b=10;
	printf("%d %d", t.a, t.b);
	return 0;
}

这段代码的输出值为10 10。所以就理所当然的认为它就是存储最后赋的值。但是,把联合的一个数据类型改一下看看。

#include <stdio.h>
union u{
	int a;	
	short b;
};
int main()
{
	union u t;
	t.a=100000;
	t.b=10;
	printf("%d %hd", t.a, t.b);
	return 0;
}

输出结果为: 65546 10。提出疑问,为什么第一个值不是10呢,别急,再看下面这个代码。

#include <stdio.h>
union u{
	int a;	
	short b;
};
int main()
{
	union u t;
	t.a=2000;
	t.b=10;
	printf("%d %hd", t.a, t.b);
	return 0;
}

输出结构又变成了:10 10。
所以综合这三段代码可以这样理解:给联合中的成员赋值时,只会对这个成员所属的数据类型所占内存空间的大小覆盖成后来的这个值,而不会影响其他位置的值。
对于第一段代码:成员为两个int类型变量,第一次给a赋值为20,它占4个字节,第二次给b赋值10,会把10(高位补零)覆盖int类型所占的4个字节(32位),所以最后a和b都是10。
对于第二段代码:成员a为int类型,b为short类型,第一次给a赋值100000,二进制为0000 0000 0000 0001 1000 0110 1010 0000,第二次给b赋值,由于short只占2个字节,所以只会覆盖16位二进制,0000 0000 0000 1010,最后的结果是0000 0000 0000 0001 0000 0000 0000 1010(从低位覆盖),所以输出结果为65546。
对于第三段代码:由于给int类型的a赋值的二进制展开只有在低两个字节内出现1,所以给short类型的b赋值时,会把a全部覆盖掉,所以两个的结果都为10。

  • 20
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

H4ppyD0g

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

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

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

打赏作者

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

抵扣说明:

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

余额充值