您的位置:首页 > 编程语言 > C语言/C++

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

2009-10-10 20:35 267 查看
<!--
@page { size: 21cm 29.7cm; margin: 2cm }
PRE { font-family: "Bitstream Vera Sans" }
P { margin-bottom: 0.21cm }
-->
-------------------------------------------------------------------------------------------

经典问题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了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: