表达式求值的顺序一部分是由操作符的优先级和结合性决定。同样,有些表达式的操作数在求值的过程中可能需要转换为其他类型。
1. 什么是整型提升?
C的整型算术运算总是以缺省整型类型的精度来进行的。为了获得这个精度,表达式中的字符和短整型操作数在使用之前被转换为普通整型,这种转换称为整型提升。
char类型的b,c先转换为int类型的b,c再进行相加 ---- 整型提升
计算结果b+c为int型,存储到char类型的a中,发生截断 ----整形截断
整型提升的意义:
表达式的整型运算要在CPU的相应运算器件内执行,CPU内整型运算器(ALU)的操作数的字节长度一般就是int的字节长度,同时也是CPU的通用寄存器的长度。因此,即使两个char类型的相加,在CPU执行时实际上也要先转换为CPU内整型操作数的标准长度。
通用CPU(general-purpose CPU)是难以直接实现两个8比特字节直接相加运算(虽然机器指令
中可能有这种字节相加指令)。所以,表达式中各种长度可能小于int长度的整型值,都必须先转
换为int或unsigned int,然后才能送入CPU去执行运算。
2. 如何进行整体提升呢?
整形提升是按照变量的数据类型的符号位来提升的
① 负数的整形提升
char c1 = -1-1的补码 11111111 11111111 11111111 11111111
char类型只有8bit位,存储为:11111111
因为char类型是有符号的char,当需要整型提升的时候:高位补符号位即1
提升后为:11111111 11111111 11111111 11111111
② 正数的整形提升
char c2 = 1
1的补码 00000000 00000000 00000000 00000001
char类型只有8bit位,存储为:00000001
因为char类型是有符号的char,当需要整型提升的时候:高位补0
提升后为:00000000 00000000 00000000 00000001
温馨提示:char默认有符号,等同与signed char。无符号表示为unsigned char。
也就是说:有符号的整型提升时高位补符号位,即负数补1正数补0
无符号的整形提升时高位直接补0
实例1: 输出结果是多少?
答案:-127
分析:
示例2:输出界面有哪些变量?
答案:c
a,b要进行整形提升,但是c不需要整形提升。
a,b整形提升之后,变成了负数,所以表达式 a==0xb6 , b==0xb600 的结果是假,但是c不发生整形提升,则表达式 c==0xb6000000 的结果是真.
所以程序输出的结果是: c
实例3 :
答案: 1 4 4
c只要参与表达式运算,就会发生整形提升。表达式 +c ,表达式 -c 参与表达式运算,都会发生整型提升,所以sizeof(+c)与sizeof(-c)都是4个字节;
但 sizeof(c) ,就是1个字节。