c语言中整型算术运算总是至少以缺省整型(缺省整型(通常指int类型) :这是 C 语言中整数类型的默认基准,int的大小由编译器和系统架构决定(通常为 32 位,可存储范围约 ±21 亿),它是整型运算的 "基准精度"。)的精度来进行的
为了获得这个精度,表达式中的字符和短整型操作数在使用之前被转换为普通整型
这种转换称为整型提升
如何整型提升
1.有符号整型提升是按变量的数据类型的符号位来提升的
2.无符号位提升,高位补0
cpp
#include <stdio.h>
int main()
{
//运算前 ------a和b自动进行整型提升(转为int类型)
char a = 3;//char--signed char
//a=00000011(char只有八个比特位)
char b = 127;//01111111=b
//a = 3(0000 0011):符号位为 0,提升为int后,高位填充 24 个 0,结果为 0000 0000 0000 0000 0000 0000 0000 0011(十进制仍为 3)。
//b = 127(0111 1111):符号位为 0,提升为int后,高位填充 24 个 0,结果为 0000 0000 0000 0000 0000 0000 0111 1111(十进制仍为 127)。
//运算中 ------ 以int类型精度执行加法运算
char c = a + b;
//a+b=130=0000 0000 0000 0000 0000 0000 1000 0010
//运算后 ------ 将int类型结果隐式转换为char类型(赋值给c)
printf("%d\n", c);
return 0;
}

整型提升是 "运算过程中" 的精度保证,运算完成后,由于要将结果赋值给char类型变量c,会发生隐式类型转换(截断转换),这一步与整型提升无关,是赋值阶段的类型适配:
char仅占 8 位,因此会将 32 位int结果130的低 8 位截断保留,丢弃高位的 24 个 0。- 截断后得到 8 位二进制:
1000 0010(这是c的存储值,占 1 字节)。 - 由于
c是signed char,存储的是补码,需要解析补码得到实际值:-
补码取反(所有位取反):
补码:
1111 1111 1111 1111 1111 1111 1000 0010取反:
0000 0000 0000 0000 0000 0000 0111 1101 -
加 1:
0111 1101+1=0111 1110所以绝对值部分是
0000 0000 0000 0000 0000 0000 0111 1110。 -
加上符号位(负数):
1000 0000 0000 0000 0000 0000 0111 1110符号位是第 1 位(1 表示负),其余 31 位是 0...01111110
-
所以最后c等于-126而不是130
-