《程序员面试宝典》第二版的 错误修正

第一处 P38

下面程序的输出结果是多少

 

void main()  
 {  
    unsigned int a = 0xFFFFFFF7;  
    unsigned char i = (unsigned char)a;  
    char* b = (char*)&a;  
   
    printf("%08x, %08x\n", i, *b);  
 }  

1 void main() 2 { 3 unsigned int a = 0xFFFFFFF7; 4 unsigned char i = (unsigned char)a; 5 char* b = (char*)&a; 6 7 printf("%08x, %08x\n", i, *b); 8 }

解答: 输出的结果是000000f7, fffffff7。变量i的输出是没有疑问的,unsigned int到unsigned char直接截断,取低字节。

对于变量b,在第5行中,书中解释是这一行等价于

  1. unsigned int* p = &a; // p中的内容是的地址,即p指向a 
  2. char* b = (char*)p; // 此处的强制转换只是使b也指向a而已 
  3. // 这里是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.

 

 

 

 

 

你可能感兴趣的:(面试)