来看一道笔试题目:
32 位机上根据下面的代码,问哪些说法是正确的?
signed char a = 0xe0;
unsigned int b = a;
unsigned char c = a;
A. a>0 && c>0 为真 B. a == c 为真 C.b 的十六进制表示是:0xffffffe0 D. 上面都不对正确答案是选C。
在数值为不同类型之间转换是,需要符号扩展。先来看一个例子:
signed char a = 0x80;
int b=a;
cout<<b;
输出-128。因为a是有符号的,b也是有符号的,a的值-128直接赋给b,无歧义。
再看一个例子:
unsigned char a = 0x80;
int b=a;
cout<<b;
输出128。a是无符号处,值为128,此处直接赋值给b。
signed char a = 0x80;
unsigned b=a;
cout<<b<<endl;
printf("%x\n",a);
输出是:
4294967168
ffffff80
由此可以明白,当有符号char赋值给有符号int时,是值赋值,直接把char的真实值给int。如果有有符号char赋值给int时,多出来的位需要符号扩展,扩展的值是有符号char的符号位。
至于B为什么不对,个人写代码测试了一下,a的值是-32(a==-32为真),c是224(c==224是真),应该是在==判断时都做了类型转换。