#include <iostream>
#include <string.h>
using namespace std;
int main()
{
char a = -1;
unsigned char b = 255;
printf("a = 0x%x b = 0x%x \n", a, b);
system("pause");
return 0;
}
运行结果如下:
解析:
之所以两者在输出结果上不一样是因为%x是打印无符号整型(unsigned int)的16进制。因此在打印时,存在如下两种隐式的类型转换:
注1:
因为在编码为补码的情形下,类型提升有两种情况:
1. 符号扩展:对于有符号数,扩展存储位数的方法。在新的高位字节使用当前最高有效位即符号位的值进行填充。(符号位都是用0表示“正”,用1表示“负”)
2. 零扩展:对于无符号数,扩展存储位数的方法。在新的高位直接填0。
注2:
-5对应正数5(原码:00000101)→所有位取反(反码:11111010)→加1(补码:11111011)
1、char => unsigned int :a在计算机系统存储为0xff,由于是符号扩展,所以对应于无符号整型数为:0xffffffff。
2、unsigned char => unsigned int :b在计算机系统存储为0xff,由于是零扩展,所以对应于无符号整型数仍为:0xff。
参考博文: