原题是:
下面的程序的结果是多少?(中国著名通信企业S公司07年8月的面试题)
输出结果是:000000f7,fffffff7.
我们用VC6.0调试得到这段程序的反汇编代码,代码如下:
通过这段汇编代码,我们容易看到:
[1] 对于unsigned char i = (unsigned char)a;这条语句的执行过程可以看出,有个数据截断的过程,将a的低八位赋值为i。
[2] 对于char* b = (char*)&a;语句,首先将a的地址存储到一个寄存器中,然后直接赋给了b。所以b指向的地址也是a的内存地址。后面的*b当然就指向了这块内存的内容了,即fffffff7.
下面的程序的结果是多少?(中国著名通信企业S公司07年8月的面试题)
#include <stdio.h>
int main()
{
unsigned int a = 0xFFFFFFF7;
unsigned char i = (unsigned char)a;
char* b = (char*)&a;
printf("%08x, %08x", i, *b);
return 0;
}
输出结果是:000000f7,fffffff7.
我们用VC6.0调试得到这段程序的反汇编代码,代码如下:
5: unsigned int a = 0xFFFFFFF7;
00401028 mov dword ptr [ebp-4],0FFFFFFF7h
6: unsigned char i = (unsigned char)a;
0040102F mov al,byte ptr [ebp-4]
00401032 mov byte ptr [ebp-8],al
7: char* b = (char*)&a;
00401035 lea ecx,[ebp-4]
00401038 mov dword ptr [ebp-0Ch],ecx
通过这段汇编代码,我们容易看到:
[1] 对于unsigned char i = (unsigned char)a;这条语句的执行过程可以看出,有个数据截断的过程,将a的低八位赋值为i。
[2] 对于char* b = (char*)&a;语句,首先将a的地址存储到一个寄存器中,然后直接赋给了b。所以b指向的地址也是a的内存地址。后面的*b当然就指向了这块内存的内容了,即fffffff7.