表达式求值 -- 整型提升

表达式求值的顺序一部分是由操作符的优先级和结合性决定。同样,有些表达式的操作数在求值的过程中可能需要转换为其他类型。本篇涉及到原反补码相互转换,还没有完全掌握的小伙伴,可以先看原反补转换 ~


 

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: 输出结果是多少?表达式求值 -- 整型提升_第1张图片

 答案:-127

 分析:表达式求值 -- 整型提升_第2张图片

 示例2:输出界面有哪些变量?

表达式求值 -- 整型提升_第3张图片

答案:c 

a,b要进行整形提升,但是c不需要整形提升。
a,b整形提升之后,变成了负数,所以表达式 a==0xb6 , b==0xb600 的结果是假,但是c不发生整形提升,则表达式 c==0xb6000000 的结果是真.
所以程序输出的结果是: c

实例3 :sizeof计算的结果分别是多少?

表达式求值 -- 整型提升_第4张图片

答案: 1 4 4

c只要参与表达式运算,就会发生整形提升。表达式 +c ,表达式 -c 参与表达式运算,都会发生整型提升,所以sizeof(+c)与sizeof(-c)都是4个字节;

但 sizeof(c) ,就是1个字节。

你可能感兴趣的:(新手村民,C语言,开发语言,后端,c语言)