一道类型转化题的汇编分析

原题是:
下面的程序的结果是多少?(中国著名通信企业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.

你可能感兴趣的:(C++,c,面试,C#)