前言
数据有不同的类型,不同类型的数据之间混合运算时,必然涉及到类型的转换问题。
类型转换的方法有两种:自动转换和强制类型转换。
一、自动转换
遵循一定的原则,由编译系统自动完成。自动转换的原则(占用内存字节数少(值域小)的类型,向占用内存字节数多(值域大)的类型转换,以保证精度不降低。):
- 当表达式中出现char、short、int、int类型中的一种或多种,没有其他类型了,参与运算的成员全都转成int类型参加计算,结果也是int类型的。
printf("%d", 5 / 2);//结果是2
- 当表达式中出现了带小数点的实数,参加运算的成员全部变成double类型的参加运算,结果也是double。
printf("%lf", 5.0 / 2);//结果是2.5
- 当表达式中有有符号数,也有无符号数,参加运算的成员变成无符号数参加运算,结果也是无符号的(表达式中无实数)。
int main() {
//测试
int a = -8;
unsigned b = 7;
if (a + b > 0)
{
printf("a+b > 0\n");//这一条被执行
}
else if (a + b < 0)
{
printf("a+b < 0\n");
}
else
{
printf("a+b = 0\n");
}
printf("a+b = %d\n", a + b);//结果是-1
printf("%d", 0xffffffff);//结果也是-1
return 0;
}
上面例子执行了a+b>0,但是又打印了a+b=-1,是因为a+b的值以反码的形式存储,后面又使用%d而不是无符号来输出,程序并不知道这个值是无符号的而是当成默认值int来处理了。
- 在赋值语句中等号右边的类型自动转为等号左边的类型,然后再进行赋值。
int a = 10;
float b = 5.5;
a = b;
printf("%d\n", a);//结果是5
- 类型自动转换都是在运算过程自动完成的临时性的转换,并不会影响变量的原本的值和类型。比如 int + unsigned int 后,前面的int并不会因此就变成了unsigned int。
二、强制类型转换
(类型说明符)(表达式) 例子:(float)a 、 (float)(a+b)
把表达式的运算结果强制转换成类型说明符所表示的类型。
int a = 10;;
float b;
b = (float)a;
printf("%f\n", b);//结果是10.000000