一、整型提升
整型提升:表达式的字符和短整型操作数在使用之前被转换位普通整型。
整型提升是按照变量的数据类型的符号位来提升的,对于无符号整型提升,高位补0。
例如:
char a = 5;
char b = 126;
char c = a + b;
printf("%d",c);
因为a是字符型的变量,当把整数5赋值给a的时候会发生截断。
内存中的数据是以补码的形式来存储的
5的补码: 0000 0000 0000 0000 0000 0000 0000 0101
char类型只占一个字节,所以存在a中的二进制位是 0000 0101
同理,存在b中的二进制位是 0111 1110
a + b 的时候需要进行整型提升
a的整型提升:0000 0000 0000 0000 0000 0000 0000 0101
b的整型提升:0000 0000 0000 0000 0000 0000 0111 1110
a + b :0000 0000 0000 0000 0000 0000 1000 0011
存在c中的二进制位是 1000 0011
当c以%d的形式打印出来的时候,也需要整型提升,高位补符号位
c的整型提升:1111 1111 1111 1111 1111 1111 1000 0011 (补码)
将它转为原码:1000 0000 0000 0000 0000 0000 0111 1101
打印出来的就是 -125
在vs编译器中我们同样可以验证整型提升是否存在
char c = 1;
printf("%d\n", sizeof(c));
printf("%d\n", sizeof(+c));
printf("%d\n", sizeof(-c));
可以发现当发生运算后char类型从原来的一个字节变成了4个字节
二、算术转换
如果某个操作符的各个操作数属于不同类型,那么其中一个操作数的类型会转换成另一个类型。
下图是转换的层次,由下往上转换。