Java int float double 他们的运算原理是什么

System.out.println(3*0.1 == 0.3);//false
System.out.println(1*0.3 == 0.3);//true

浮点数有精度问题,所以一般都要求浮点数不要直接进行等于判断,而是定义一个误差值,两者差小于误差值时即算相等

计算机是通过移位来进行计算的,小数计算都会有误差,可能变成0.333333等情况。要四舍五入或者变为整数比较。

小数默认是double类型的,在计算过程中会存在精度丢失问题。在涉及金额等重要数值时,用BigDecimal对象来处理精度丢失问题。

你输出3*0.1和1*0.3的值就知道为什么比较的结果不一致了。

您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632