Java如何处理浮点数运算的精度问题
1、我们先看看Java中直接使用double进行浮点数运算时,出现的精度问题,测试代码如下:private void testAccuracyProblem() { double d1 = 0.01; double d2 = 0.05; double d3 = 0.06; if(Double.compare((d1+d2), d3) == 0) { System.out.println("两个数字相等!"); }else { System.out.println("两个数字不相等!"); } }上述代码运行后,输出了 "两个数字不相等!", 这就是Java中浮点运算的精度问题。

3、为啥使用 BigDecimal 类还出现精度问题呢? 问题出在这个构造函数上,我们使用一个double浮点数作为参数的构造函数来创建 BigDecimal 对象,这个构造函数创建的对象精度本身就有问题,相关API文档对这个问题也有描述(详见图示)。

5、由此,我们通过BigDecimal构建一个摆脱精度困扰的浮点数运算工具类,对应浮点数的四则运算,相关代码请参考图示。


声明:本网站引用、摘录或转载内容仅供网站访问者交流或参考,不代表本站立场,如存在版权或非法内容,请联系站长删除,联系邮箱:site.kefu@qq.com。