C语言类型转换----有符号数截断问题

程序员面试宝典中有这个一道题:下面程序的结果是多少?

#include <stdio.h>
#include <stdlib.h>

int main()
{
    unsigned int  a = 0xFFFFFFF7;
    //unsigned int  a = 0xAAAAAA07;
    unsigned char i = (unsigned char)a;
    char *b = (char *)&a;
    printf("%08x,%08x", i,*b);
    return 0;
}
  • 解析: 在X86系列的机器中,数据的存储是“小端存储”, 小端存储的意思是,对于一个跨多字节的数据,其低位存放在低地址单元,其高位存放在高地址单元。比如一个int型的数据0x12345678,假如存放在0x00000000, 0x00000001, 0x00000002, 0x00000003这四个内存单元中,那么0x00000000中存放的是低位的0x78,而0x00000003中存放的是高位的0x,依此类推。
  • 分析第二个为什么输出fffffff7, &a可以认为是个指向unsigned int 类型数据的指针,(char *)&a把&a强制转换成char 类型的指针,并且这个时候发生了截断!截断后,指针b只指向0xf7这个数据(刚刚讲的小端存储)。又由于指针b是char 型,属于有符号数,所以有符号数0xf7在printf()的作用下输出fffffff7.
  • 答案是: 000000f7, fffffff7

理解:

  • 第一个结果没有疑问。
  • 关键是第二个结果,没有考虑到b是char * 型,属于有符号数,0xf7最高位为1,应该是负数,负数要显示出来就要以补码的形式输出,所以高位不是补0而是补1,如果我把a的值改为0xAAAAAA07,结果就都是00000007.
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值