1. java对于double类型数据的计算,总会出现精度丢失的问题,这也是javaAPI提到的,所以如果想得到精确的double计算,可以采用如下方式,首先将double转换成String,然后把String转换为BigDecimal类型的数据,在进行了BigDecimal数据间的计算,通过BigDecimal的doubleValue()方法返回到double数据类型:
package com.rofine.common.utils;
import java.math.BigDecimal;
public class ToolUtil
{
public static enum OPERATION
{
ADD, MINUS, MULTI, DIV
}
public static double operate(OPERATION operation, double d1, double d2)
{
String s1 = String.valueOf(d1);
String s2 = String.valueOf(d2);
BigDecimal b1 = new BigDecimal(s1);
BigDecimal b2 = new BigDecimal(s2);
if (operation.equals(OPERATION.ADD))
return b1.add(b2).doubleValue();
if (operation.equals(OPERATION.MINUS))
return b1.subtract(b2).doubleValue();
if (operation.equals(OPERATION.MULTI))
return b1.multiply(b2).doubleValue();
if (operation.equals(OPERATION.DIV))
return b1.divide(b2).doubleValue();
return 0.0;
}
}