第一处 P38
下面程序的输出结果是多少
void main()
{
unsigned int a = 0xFFFFFFF7;
unsigned char i = (unsigned char)a;
char* b = (char*)&a;
printf("%08x, %08x\n", i, *b);
}
解答: 输出的结果是000000f7, fffffff7。变量i的输出是没有疑问的,unsigned int到unsigned char直接截断,取低字节。
对于变量b,在第5行中,书中解释是这一行等价于
- unsigned int* p = &a; // p中的内容是的地址,即p指向a
- char* b = (char*)p; // 此处的强制转换只是使b也指向a而已
- // 这里是char类型的指针转换,而不是char类型的转换,影响的只是指针的
看似好像正确,其实不然,不能因为结果对了 就去这么解释。
可以试验一下 把第一行 unsigned int a = 0xFFFFFFF7; 改为unsigned int a = 0x1FFFFFF7; 输出等等*b还是fffffff7。
到底什么原因?可见指针转换的时候并不是这么转换的。
(char*)&a 将a的地址转换成一个char型指针,和(int*)&a 转换成一个int是不同的,它只会指向&a的低8位内存,其余的发生了截断。
所以 现在b指向的是0xf7, 这是一个负数,使用%08x 输出 就是ffffffff7.