在c语言里进行表达式求值时,运算顺序一般由操作符的优先级和结合性来决定,而有些表达式的操作数在求值过程中可能需要先转换为其他类型,再参与计算。
整型提升:
c语言的整型算术运算总是至少以缺省型类型的精度来进行的(char也算整型),为了获得这个精度,表达式中的字符和短整型操作数在使用之前被转换为普通整型,这种转换称为整型提升。也就是说,表达式中各种长度可能小于int长度的整型值,都必须先转换为int或者unsigned int,才能送入CPU去执行运算。
那么,如何进行整型提升呢?
整型提升是按照变量的数据类型的符号位来提升的,规则如下:
负数的整型提升:高位补1
正数的整型提升:高位补0
无符号数的整型提升:高位补0
下面举个栗子(仔细看注释):
#include<stdio.h>
int main()
{
char c1=3;
//00000011-------c1 整数放到char类型里发生截断
char c2=127;
//00000000000000000000000001111111
//01111111------->c2 发生截断
char c3= c1+c2;
//c1+c2运算时先提升为整型 00000000000000000000000010000010
//10000010-------c3 发生截断
printf("%d\n",c3); //转换为整型,c3整型提升
//11111111111111111111111110000010--------这是补码,转为原码为-126
return 0;
}
ps: 和char一样,short在计算过程中也会进行整型提升。
证明整型提升存在的栗子:
#include<stdio.h>
int main()
{
char c=1;
printf("%u\n",sizeof(c));//1
printf("%u\n",sizeof(-c));//4
printf("%u\n",sizeof(+c));//4
//只要char类型的数参与运算,就会发生整型提升,所以计算结果为整型
//%u 无符号10进制整数
return 0;
}
算术转换:
以上是与int短的变量类型一起参与运算的,在与int长的变量类型一起参与运算时,较短的要转化为较长的去参与运算,即采用算术转换。
eg:
long与double类型一起参与运算时,long先转化为double,再一起参与运算;
int与double类型一起参与运算时,int先转化为double,再一起参与运算
......