1、java的float和double是给科学计算用的,也就是说不能用于商业计算;
2、如果是商业计算那么必需使用java.math.BigDecimal,且必需要使用string来构造;
最后我们利用BigDecimal提供的精确计算来对最开始提到的例子进行测试
public class Test {
public static void main(String[] args) {
//直接使用浮点数进行计算,得到的结果是有问题的
System.out.println(0.01+0.05);
//使用了BigDecimal类进行计算后,可以做到精确计算
System.out.println(Arith.add(0.05, 0.01));
}
}
控制台输出:
0.060000000000000005
0.06