Union类型的一道笔试题

 

题目:

看程序写出输出结果

 

基本概念:

这题涉及到Union的内存分配问题和大小端的问题。

下面先对大小端和Union内存分配的概念进行讲述。

1.  小端模式: 字数据的高字节存放在高地址中,而字数据的低字节则存放在低地址中。

2.  大端模式: 字数据的高字节存放在低地址中,而字数据的低字节则存放在高地址中。

3.  Union类型的数据所占的空间等于最大的成员所占的空间,对union 型的成员的存取都是相对于该联合体基地址(低地址)的偏移量为0处开始,也就是联合体的访问不论对哪个变量的存取都是从union的首地址位置开始,因此,大小端模式存储将会直接影响union内成员的值。

 

分析过程:

由于我机器是小端机器,obj.i= 0x41424344的内存存储如下:

0x0003

0x0002

0x0001

0x0000

41(‘A’)

42(‘B’)

43(‘C’)

44(‘D’)

而对于ch这个内部结构来说,ch.a对应于0000位置,ch.d对应于0003位置:

0x0003

0x0002

0x0001

0x0000

 

 

41(‘A’)

42(‘B’)

43(‘C’)

44(‘D’)

 

 

 

Ch.d

Ch.c

Ch.b

Ch.a

 

 

 

于是在     cout << obj.ch.a << ' ' << obj.ch.b  << ' ' << obj.ch.c << ' ' << obj.ch.d<< endl;

输出结果为DCBA的顺序。

同样,当

obj.ch.a = 'a';

         obj.ch.b = 'b';

         obj.ch.c = 'c';

         obj.ch.d = 'd';

内存的分布如下:

0x0003

0x0002

0x0001

0x0000

‘d’(64)

‘c’(63)

‘b’(62)

a(61)

于是obj.i输出的值为64636261的顺序。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值