union u_type
{ int i;
char ch;
float a;
}temp;
现在windows环境下,执行"temp.i=266;printf("%d",temp.ch)"的结果是( )。
A、266
B、256
C、10
D、1
为什么会是C?
13 个解决方案
#1
因为他们公用同一处内存。
temp.i = 266 ,使那块内存为266,十六进制为 00 00 01 0A
由于使用little - endian 分配, 所以内存顺序为 0A 01 00 00
char 一个字节,指向首地址。 0A,而0A = 10
所以选C 10。
temp.i = 266 ,使那块内存为266,十六进制为 00 00 01 0A
由于使用little - endian 分配, 所以内存顺序为 0A 01 00 00
char 一个字节,指向首地址。 0A,而0A = 10
所以选C 10。
#2
266 转2进制 10001010 int是2位 char 1位 所以char分到了1010 转10进制是10
#3
是字节 口误
#4
不对,我好像回答的有点小问题。 忘记float了。
#5
刚才的16进制,前面加4个0,方法不变。
#6
测试一下不就知道?
#7
联合体的总长度为4个字节。那么
temp.i = 266 ,这四个字节里存放的为266,十六进制为 00 00 01 0A,而char ch;为一个字节,所以取的是第一个字节(根据小端)即0x0A;就是10。
temp.i = 266 ,这四个字节里存放的为266,十六进制为 00 00 01 0A,而char ch;为一个字节,所以取的是第一个字节(根据小端)即0x0A;就是10。
#8
google 大小端
#9
VC调试时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Turbo C或Borland C用Turbo Debugger调试,Linux或Unix下用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Turbo C或Borland C用Turbo Debugger调试,Linux或Unix下用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!
#10
1楼正解
#11
与大小端有关。
#12
++
#13
大小端的问题 不过float类型要注意了
#1
因为他们公用同一处内存。
temp.i = 266 ,使那块内存为266,十六进制为 00 00 01 0A
由于使用little - endian 分配, 所以内存顺序为 0A 01 00 00
char 一个字节,指向首地址。 0A,而0A = 10
所以选C 10。
temp.i = 266 ,使那块内存为266,十六进制为 00 00 01 0A
由于使用little - endian 分配, 所以内存顺序为 0A 01 00 00
char 一个字节,指向首地址。 0A,而0A = 10
所以选C 10。
#2
266 转2进制 10001010 int是2位 char 1位 所以char分到了1010 转10进制是10
#3
是字节 口误
#4
不对,我好像回答的有点小问题。 忘记float了。
#5
刚才的16进制,前面加4个0,方法不变。
#6
测试一下不就知道?
#7
联合体的总长度为4个字节。那么
temp.i = 266 ,这四个字节里存放的为266,十六进制为 00 00 01 0A,而char ch;为一个字节,所以取的是第一个字节(根据小端)即0x0A;就是10。
temp.i = 266 ,这四个字节里存放的为266,十六进制为 00 00 01 0A,而char ch;为一个字节,所以取的是第一个字节(根据小端)即0x0A;就是10。
#8
google 大小端
#9
VC调试时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Turbo C或Borland C用Turbo Debugger调试,Linux或Unix下用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Turbo C或Borland C用Turbo Debugger调试,Linux或Unix下用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!
#10
1楼正解
#11
与大小端有关。
#12
++
#13
大小端的问题 不过float类型要注意了