先来看一个例子:
System.out.println(2.0 - 1.1);
结果为:
0.8999999999999999
很明显,这不是我们开发中需要的精度,我们需要得到更准确的结果。这里,引入BigDecimal类(Math包里的类),示例:
import java.math.BigDecimal;
BigDecimal bd1 = new BigDecimal(2.0);
BigDecimal bd2 = new BigDecimal(1.1);
System.out.println(bd1.subtract(bd2));
BigDecimal bd3 = new BigDecimal("2.0");
BigDecimal bd4 = new BigDecimal("1.1");
System.out.println(bd3.subtract(bd4));
运行结果:
0.899999999999999911182158029987476766109466552734375
0.9
注意应当以字符串形式传入BigDecmal,进行运算,才是我们开发中需要的精确结果。
第二种方式:
BigDecimal bd5 = BigDecimal.valueOf(2.0);
BigDecimal bd6 = BigDecimal.valueOf(1.1);
System.out.println(bd5.subtract(bd6));
运行结果:
0.9
这种方式在开发中也是可以的。