Java中new BigDecimal(double val)的坑

在计算机中浮点数有可能是不准确的,它只能无限接近准确值,不能完全精确。new BigDecimal(double)类型时,小数的精度出现扩展。double 表示的小数是不精确的,如 0.1 这个数字,double 只能表示它的近似值。所以,当使用 new BigDecimal(0.1)创建一个 BigDecimal 的时候,其实创建出来的值并不是正好等于 0.1 的。而是 0.1000000000000000055511151231257827021181583404541015625。这是因为 doule 自身表示的只是一个近似值。所以,如果我们在代码中,使用 BigDecimal(double) 来创建一个 BigDecimal 的话,存在精度损失风险,在精确计算或值比较的场景中可能会导致业务逻辑异常。
如果使用new BigDecimal(double)时,正确的方式是使用入参为String的构造方法,或者使用BigDecimal的valueOf方法,这是因为该方法内部其实执行了Double的toString,而Double的toString按double的实际能表达的精度对尾数进行了截断。
例子:
System.out.println(new BigDecimal(0.725D));
System.out.println(new BigDecimal(Double.valueOf("0.725")));
System.out.println(BigDecimal.valueOf(0.725D));
System.out.println(new BigDecimal("0.725"));
System.out.println(new BigDecimal(Double.valueOf("0.725").toString()));
输出结果如下:
0.72499999999999997779553950749686919152736663818359375
0.72499999999999997779553950749686919152736663818359375
0.725
0.725
0.725

你可能感兴趣的:(Java中new BigDecimal(double val)的坑)