最近在工作中碰到一个关于double精度的问题,记录下。
首先见如下代码,最终的计算结果是不相等的,因为最终invoiceItemMoneyAmount的值变成了168.82000000000002
double money= 168.82;
List<String> itemMoneyList = Lists.newArrayList();
itemMoneyList.add("23.80");
itemMoneyList.add("3.00");
itemMoneyList.add("142.02");
double invoiceItemMoneyAmount = 0.00;
for(String itemMoney : itemMoneyList){
invoiceItemMoneyAmount = invoiceItemMoneyAmount + Double.valueOf(itemMoney);
}
if(money == invoiceItemMoneyAmount)
System.out.println("hello world");
为什么是这样呢?研究了下,查了一些资料,原因是这样的:
在Java中浮点数类型:double,一般不能进行运算,不只是Java,其他语言也是这样的。在effective Java一书中也有提到过,double一般只能用作科学计算或者工程计算,在商业计算中一般使用java.math.BigDecimal,所以需要通过BigDecimal的add方法来进行计算就可以解决这个问题。
如下代码,结果计算就是相同的了。
double money= 168.82;
List<String> itemMoneyList = Lists.newArrayList();
itemMoneyList.add("23.80");
itemMoneyList.add("3.00");
itemMoneyList.add("142.02");
BigDecimal invoiceItemMoneyAmount = new BigDecimal("0");
for(String itemMoney : itemMoneyList){
invoiceItemMoneyAmount = invoiceItemMoneyAmount.add(new BigDecimal(itemMoney));
}
if(money == invoiceItemMoneyAmount.doubleValue())
System.out.println("hello world");