展开全部
int型的变量 占2个字节,而一个内存单元只有一个字节的大小,因此int型变量要分开放。
那怎么放呢?是这样的,先把int变量分成两个字节,前八位作为高字节,后八位作为低字节,这样,把高字节的那八位放在低地址内存单元,低字节的那八位放在高地址内存单元。
而long型的占四个字节,也是一样的,分成四个字节分开放,高字节放低地址内存单元。
你的程序中,只占一个字节的0x39给了int型的i[0],那这样,高字节为0,假设放在最低地址的内存单元中,那0x39就顺着往上放,i[1]也一样。好了,这样放完后,这个占四个字节的共用体变量的存储情况就是:0x38 / 0x00 / 0x39 / 0x00 (说明:左手边为高地址,右手边为低地址)。
i[1] i[0]
好了,我们现在是取long型的k,那很显然,低地址的存储单元是它的高字节,高地址的存储单元是它的低字节,这样就得到:0x 00 39 00 38 。
这是我用keil-C51仿真得到的结果,如果你问为什么结果跟你的不一样,那我只能回答:系统决定变量的存放方式。
展开全部
计算机存储的时候是把! 高位存在高地址 地位存在低地址! k占用两个字节,k的高位对应的就是共用体数组i的i[1],低位对应的就是i[0]
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
图上已经画的很明白了啊,这个共用体是个两字节的对象,前一个字节是0x02,后一个字节是0x00,所以在printf的时候,先按照短整型取出数据0x0002(注意x86架构是小端模式,低字节在前),再promote成为整型0x00000002,最后输出的结果是2。
好好学习天天向上
好好学习天天向上
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
共用体,就是成员变量共用内存地址。
这里内存低地址(r.i[0]),高地址(r.i[1]),分别存储十进制数2和0。在内存中以2进制存储,就分别是:
00000010和00000000。
当大端模式,高位数据在低地址,r.k读取的数字就是
00000010,00000000,也就是十进制的512。
当小端模式,高位数据在高地址,r.k读取的数字就是
00000000,00000010,也就是十进制的2。
所以你图中结果,是因为你电脑是小端模式。
这里内存低地址(r.i[0]),高地址(r.i[1]),分别存储十进制数2和0。在内存中以2进制存储,就分别是:
00000010和00000000。
当大端模式,高位数据在低地址,r.k读取的数字就是
00000010,00000000,也就是十进制的512。
当小端模式,高位数据在高地址,r.k读取的数字就是
00000000,00000010,也就是十进制的2。
所以你图中结果,是因为你电脑是小端模式。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
共用体即共用体里面的成员共享同一块内存空间,至于这块内存空间多大由其中某个占用最大内存空间的数据成员决定。共用体的输出涉及到数据存储的方式,分大端模式与小端模式(关于大小端具体自己在百度),你这里的结果并不是绝对的,只是恰巧你的这个平台的数据存储模式属于小端模式,所谓小端模式就是数据的低字节放在内存的低地址,高字节放在高地址,大端模式则是相反。所以你这个程序碰到是大端模式的平台的话,那结果输出的就是0x0200
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询