经典问题5:c/c++ 程序设计 ---usigned char类型转换问题

-------------------------------------------------------------------------------------------
经典问题5:c/c++ 程序设计 ---usigned char类型转换问题
--------------------------------------------------------------------------------------------
面试题:下面程序的结果是多少?(2009-07-26)
1 #include <stdio.h>
2
3 int main ()
4 {
5 unsigned int a = 0xFFFFFFF7;
6 unsigned char i = (unsigned char) a;
7 char *b = (char*)&a;
8 unsigned char *c = (unsigned char *)&a;
9 printf("%08x,%x,%08x /n",i,*b,*c); //%x取值是32位的
10 printf("%d,%d /n",(int)(*b),(int)(*c) );
11 return 0;
12 }
---------------
$ ./a.out
000000f7,fffffff7,000000f7
-9,247
---------------
知识点:
--(1)
7 char *b = (char*)&a;
8 unsigned char *c = (unsigned char *)&a;

little-endian的话,*b指向的是最低的那个字节也就是f7 ;而char是有符号的,高位用ff补齐,而unsigned char 是无符号的,就直接打印一个字节的内容,高字节就用0补齐
--(2)
这个结果是实现相关的,不同编译器或者同一个编译器在不同的char类型选项下,*b会呈现出fffffff7和000000f7两种结果。

为什么呢?因为c/c++标准规定char类型可以是signed char,也可以是unsigned char,这就是实现相关。 编译器可以自行选择其中一种,一般情况下编译器会提供选项让用户选择。你所得到的结果,是因为你当前编译环境设定char是signed char而得到的。 由于*b是signed char,在作为参数传printf之前,*b被自动提升为int,这是一个到signed int的转换,标准规定在这种情况下,如果*b的值能被signed int 表示,那么值不变,*b的值为f7,在signed char里表示-9,那么转换为signed int后它也应该保持-9这个值,-9在四字节signed int里面就是 fffffff7,因此才有*b = fffffff7的结果,事实上,这里从f7到fffffff7的转换就叫做符号扩展。

如果编译器设定char是unsigned char,情况就与i相同了,无符号f7值是247,转换为signed int后应该依然还是247,因此就是000000f7了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值