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

来源:互联网 发布:ubuntu 14.04 镜像源 编辑:程序博客网 时间:2024/05/22 07:40
-------------------------------------------------------------------------------------------
经典问题5:c/c++ 程序设计 ---usigned char类型转换问题
--------------------------------------------------------------------------------------------
面试题:下面程序的结果是多少?(2009-07-26)
1#include <stdio.h>
2
3int 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了。
原创粉丝点击