1.在处理金额时,由于浮点精度(float、double)运算不精确.计算结果如下显示:
double num = 0.1 + 0.1 + 0.1;
System.out.println("num = " + num); // 输出结果为0.30000000000000004
double num2 = 0.65 - 0.6;
System.out.println("num2 = " + num2);// 输出结果为 0.05000000000000004
那么精度运算不准确这是为什么呢?我们接下来就需要从计算机所有数据的表现形式二进制说起了。如果大家很了解二进制与十进制的相互转换,那么就能轻易的知道精度运算不准确的问题原因是什么了。如果不知道就让我们一起回顾一下十进制与二进制的相互转换流程。一般情况下二进制转为十进制我们所使用的是按权相加法。十进制转二进制是除2取余,逆序排列法。
2.使用BigDecimal类型作为金额处理.
BigDecimal bigD1 = new BigDecimal("8.1230000000000");
BigDecimal bigD2 = new BigDecimal("8.12300000000001");
System.out.println("金额类加法" + bigD1.add(bigD2));
BigDecimal bigD3 = new BigDecimal("8.12300009");
BigDecimal bigD4 = new BigDecimal("1.12300009");
System.out.println("金额类减法" + bigD3.subtract(bigD4));
BigDecimal bigD5 = new BigDecimal("8.1200");
BigDecimal bigD6 = new BigDecimal("9.12");
System.out.println("金额类乘法" + bigD5.multiply(bigD6));
BigDecimal bigD7 = new BigDecimal("9");
BigDecimal bigD8 = new BigDecimal("3");
System.out.println("金额类除法" + bigD7.divide(bigD8));