这次主要是基本数据类型的转换;
为什么会有数据类型的转换呢?
主要是由于在不同的情况下我们对于数值精度的要求不同,导致我们必须对一些数据进行处理。
数据类型的转换分为强制转换和隐式转换两种
强制转换:当变量的取值范围从大变小时
转换格式:另一变量名=(要转换到的类型)变量名;例如:int i=0; flaot j=10.123456; i=(int)j; 这时浮点型变量 j 的值已经变为整型并付给变量 i 。
隐式转换:当变量的取值范围从小变大时,自动转换,不用强制,例如:int i=0,float j=1.2345; j=i;
代码如下:
int main(void)
{
int i = 2;
float j = 10.123456;
float temp=0;
//(float)i = (float)i;
printf("int_change_before:");
printf("%f\n", i);
printf("int_change_after:");
temp = (float)i;
printf("%f\n",temp);
printf("float_change_before:");
printf("%f\n", j);
printf("flaot_change_after:");
temp = (int)j;
printf("%d\n", (int)temp);
return 0;
}
输出结果:
int_change_before:2
int_change_after:2.00000
float_change_before:10.123456
float_change_after:10
总结:强制转换可以帮助我们获取需要的取值,但是丢失了数的精度,具体按情况而定。