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

第一处 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行中,书中解释是这一行等价于

  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.

 

 

 

 

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值