如下图
我们定义一个浮点变量便于接收a/b的带小数结果.
而,结果显示为4.0,截掉了所有小数以后的部分.
解析: 因为ab为int型变量 运算之后所得数值也为int型数值,所以自动截掉小数位.然而接收结果的变量f为double型,存储位数以及所占空间字节数都相对int要高,所以没有报出数据类型不匹配的错误,而是运算结果的int类型自动升级为double型,进行了结果输出,从而得到4.0的结果.
下面来分析一下解决方案:
方法一:用float强制转换a/b的结果,显然,结果还是一样没有显示我们想要的值.这是因为a/b一旦独立发生运算就只有一个int的结果所以我们要在运算前就改变两个变量的属性.
方法二:强制转换参与运算的一个变量a,让其转换成float型再与int型b来做运算.根据下图,我们得到的结果正确.如前章所述
float型与int型进行运算,int型自动升级为级别更高的float型.
float型的结果赋值给double型,就自动升级为double型(事实上右侧表达式计算出来的结果在系统中就是double型)
方法三:在右侧表达式中让变量乘以1.0,也就是让int型变量与double型数据进行运算,从而让结果自动升级为double型.
浮点变量接收整数运算结果分析
最新推荐文章于 2023-12-20 11:00:34 发布