double精度处理

double类型的数据在相加后会产生浮点数,对于金额来说需要精确到两位
如:amount_sum=387576.23999999993

public static double round(double d, int num) {
BigDecimal b = new BigDecimal(Double.toString(d));
BigDecimal one = new BigDecimal("1");
//修正数值操作中非保留有效位除法导致数据失真
BigDecimal r = b.divide(one,num,BigDecimal.ROUND_HALF_UP);
//计算num+1位小数四舍五入值e
BigDecimal e = b.divide(one,num+1,BigDecimal.ROUND_HALF_UP);
//计算num+5位小数四舍五入值s
BigDecimal s = b.divide(one,num+5,BigDecimal.ROUND_HALF_UP);
//如果s与e数值之间的差距在10^(-(num+5))内,则系统认为是计算中精度问题,并根据s的数值来修正原四舍五入r的结果
if(Math.abs(s.doubleValue()-e.doubleValue()) < Math.pow(0.1, num+5)) r = s.divide(one,num,BigDecimal.ROUND_HALF_UP);
        return r.doubleValue();
 }

猜你喜欢

转载自liuestc.iteye.com/blog/2323830