C语言的类型转换分为自动类型转换和强制类型转换
下面我们先来讨论一下自动类型转换:
自动类型转换遵循下面的规则:
1、若参与运算的数据类型不同,则先转换为同一类型,然后在进行运算。
2、转换按数据长度增加的方向进行,以保证精度不降低。例如int型和long型运算时,先把int量转成long型后再进行运算
3、所有的浮点数运算都是以双精度进行的,即使仅含有float单精度量运算的表达式,也要先转换成double型后再进行运算。
4、char型和short型参与运算的时候,必须先转换成int型。
5、在赋值运算中,赋值号两边的数据类型不同时,需要把左边的表达式的类型转换成左边变量的类型。如果右边表达式的数据类型长度比左边长时,将丢失一部分数据,这样会降低精度。
#include<stdio.h>
int main(){
float PI=3.14159;
int s1, r=5;
double s2;
s1 = r*r*PI;
s2 = r*r*PI;
printf("s1=%d, s2=%f\n", s1, s2);
return 0;
}
在这个代码中运算结果为:
s1=78, s2=78.539753
在计算表达式
r*r*PI
表达式中的r和pI都转换为double型,表达式的结果也为double型,但是由于s1为整型,所以赋值运算的结果仍为整型,舍去了小数部分。
下面我们讨论一下强制类型转换:
人为的加入要转换的类型
(float) a;//把a转换为实型
(int)(x+y);//把x+y的结果转换为整型
(float)100;//将一个常量转换为实型
#include <stdio.h>
int main(){
int sum = 17, count = 5;
double mean;
mean = (double) sum / count;
printf("Value of mean : %f\n", mean);
return 0;
}