精确计算

使用BigDecimal进行精确运算

两盒软妹~` 提交于 2019-11-27 03:59:21
首先我们先来看如下代码示例: public class Test_1 { public static void main(String[] args) { System.out.println(0.06+0.01); System.out.println(1.0-0.42); System.out.println(4.015*100); System.out.println(303.1/1000); } } 运行结果如下。 0.06999999999999999 0.5800000000000001 401.49999999999994 0.30310000000000004 你认为你看错了,但结果却是是这样的。问题在哪里呢?原因在于我们的计算机是二进制的。浮点数没有办法是用二进制进行精确表示。我们的 CPU 表示浮点数由两个部分组 成 :指数和尾数,这样的表示方法一般都会失去一定的精确度,有些浮点数运算也会产生一定的误差。如: 2.4 的二进制表示并非就是精确的 2.4 。反而最为接近的二进制表示是 2.3999999999999999 。浮点数的值实际上是由一个特定的数学公式计算得到的。 其实java 的 float 只能用来进行科学计算或工程计算,在大多数的商业计算中,一般采用 java.math.BigDecimal 类来进行精确计算。 在使用 BigDecimal