整型提升和算数转换
一.整型提升
在C语言中的整型算术运算总是至少以整型类型的精度来计算的。
为了获得这个精度,表达式中的字符和短整型操作数在使用之前被转换为普通整型,这种转换称为整型提升。
1.如何进行整型提升?
整型提升是按照变量的数据类型的符号位进行提升。
2.截断
int main()
{
char a = 3;
//此时 3 是整型的3
//补码为:00000000000000000000000000000011
//char 类型的大小是 8bit
//因此此时会发生截断
//将后面8位截断,存入变量a
return 0;
}
3.整型提升的例子
列1:
int main()
{
char a = 3;
//截断后存入
//00000011
char b = 127;
//01111111
char c = a + b;
//此时进行表达式求值需要先进行整型提升
//有符号类型按照符号位进行提升 无符号直接补0
//a :00000000000000000000000000000011
//b :00000000000000000000000001111111
//a + b : 00000000000000000000000010000010
//存入 c(char) 截断
// c : 10000010 (补码)
printf("%d\n", c); //-126
return 0;
}
列2:
int main()
{
char a = 0xb6;
short b = 0xb600;
int c = 0xb6000000;
if (a == 0xb6)
printf("a");
//a 进行整型提升 0xb6 = 10110110
//a :11111111111111111111111110110110
//比较,不成立
if (b == 0xb600)
printf("b\n");
//同理, 不成立
if (c == 0xb6000000)
printf("c\n");
// c 本来就是整型无需进行整型提升
//成立
return 0;
}
列3:
int main()
{
char a = 1;
printf("%u\n", sizeof(a)); //1
printf("%u\n", sizeof(+a));//4
//(+a)也算是一个表达式 进行整型提升
printf("%u\n", sizeof(-a));//4
return 0;
}
总结:在我们进行表达式运算时,小于整形的需要进行整型提升
二.算数转换
如果表达式的某个操作符的各个操作数属于不同的类型(>=整型),那么除非其中一个操作数的转换为另一个操作数的类型,否则操作就无法进行。
算数转换表:由下向上进行转换。
long double
double
float
unsigned long int
long int
unsigned int
int
注意:
算术转换要合理,不然会有一些潜在的问题。
总结:当表达式的操作数属于不同类型的时候,需要进行算数转换。