【C/C++】类型提升

#include 
#include 

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。


参考博文:

C语言中的类型提升——基础概念,但还有很多人搞不清

你可能感兴趣的:(C/C++,Learn)