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

2023-10-31

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

#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.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

C语言类型转换----有符号数截断问题 的相关文章

随机推荐