最近群里讨论了一道题目:
--------------------------------------------------------------
char *str = "/x01/x23/x45/x67/x89/xab/xcd/xef";
while(*str!='/0')
printf("%x/n",*str++);
--------------------------------------------------------------
这段代码的输出结果是什么?经运行是:
1
23
45
67
ffffff89
ffffffab
ffffffcd
ffffffef
为什么前面的正常输出,而后面的89,ab,cd,ef输出不是预想的呢?百度了一下,查到了根由。
c语言中,char类型默认8个bit,/x01 /x23 /x45 /x67每个也是占8个bit,它们的二进制表示,分别是00000001,00100011,01000101,01100111。而x89/xab/xcd/xef的二进制表示是10001001,10101011,11001101,11101111。查询printf()函数的%x输出解释:Print an unsigned int as a hexadecimal number. ‘x’ uses lower-case letters and ‘X’ uses upper-case.也就是按照无符号整型输出,而无符号整型占32bits,那么要进行位扩展。位扩展的原则是:对有符号数,扩展存储位数的方法是对于新的高位字节,使用当前最高有效位(符号位)的值进行填充,即为符号扩展;而对于无符号数,则是对高位直接填零,即为零扩展。
那么本题就可以解释了,str为有符号字符,扩展最高位,则诸如/x89要扩展成11111111111111111111111110001001既十六位的ffffff89,其他类推。