一:整型提升的介绍:
整型提升主要存在表达式求值之中。有些表达式的操作数在求值的过程中可能需要转换为其他类型。
隐式类型转换:
C语言的整型算术运算总是至少以缺省整型类型的精度来进行的。
为了获得这个精度,表达式中的字符和短整型操作数在使用之前被转换为普通整型,这种转换称为整型提升。
二:整型提升的原理:
上面这段话总而言之就是cpu的相应运算器件内的运算规则是要进行整型相加相减的。因此,两个不够整型的数进行相加,比如是char等等,就会进行整型提升。提升后才能在cpu里面进行运算。
三:如果进行整型提升:
整型提升是按照变量的数据类型的符号位来提升的
(1)正数整型提升:
(2)负数整型提升:
例如:
-1是整数是32个比特位,此时算出-1的补码。因为char只有一个字节,也就是8个比特位,因此把前面的24位给截断。此时就是c的值。而如果要整形提升,char c是有符号char,因此11111111的第一位解读为符号位,前面全部补上符号位,也就是1。
注意:如果是无符号为,高位直接补0。
四:一些例子:
先把a,b的补码算出来,然后存到a,b里面,又因为a,b是char类型,那么就要对a,b的二进制进行截断。又因为a+b在一个表达式内达不到整形大小,所以要整形提升。提升完赋值给c,c是char类型,所以又要进行截断。又因为打印是要%d整数,所以要整型提升。高位是1,全部补1。再求原码。