阅读背景:

解决double类型运算时精度丢失问题

来源:互联网 
package org.eredlab.g4.ccl.util;

/*
 *******************************************************************
 * Copyright     TOPCASE   2009                       			  *
 *******************************************************************
 *                                                                 *
 *  PROGRAM ID     -                                               *
 *  FILE TYPE      - JAVA                                          *
 *  DATE GENERATED - 2009-9-24                                       *
 *  DESCRIPTION    -     			                       		  *
 *  AUTHOR         - syler                                       *
 *  DOCUMENT       - .doc 			                              *
 *  DATE UPDATED   -                                               *
 *  REASON         -                                               *
 *  AUTHOR         -                                               *
 *  DOCUMENT       -                                               *
 *                                                                 *
 *******************************************************************
 */



import java.math.BigDecimal;

/**
 * @author syler 解决double类型运算时精度丢失问题
 */
public class MathUtil {
	/**
	 * 对double数据进行取精度.
	 * 
	 * @param value
	 *            double数据.
	 * @param scale
	 *            精度位数(保留的小数位数).
	 * @param roundingMode
	 *            精度取值方式.
	 * @return 精度计算后的数据.
	 */
	public static double round(double value, int scale, int roundingMode) {
		BigDecimal bd = new BigDecimal(value);
		bd = bd.setScale(scale, roundingMode);
		double d = bd.doubleValue();
		bd = null;
		return d;
	}

	/**
	 * double 相加
	 * 
	 * @param d1
	 * @param d2
	 * @return
	 */
	public static double sum(double d1, double d2) {
		BigDecimal bd1 = new BigDecimal(Double.toString(d1));
		BigDecimal bd2 = new BigDecimal(Double.toString(d2));
		return bd1.add(bd2).doubleValue();
	}

	/**
	 * double 相减
	 * 
	 * @param d1
	 * @param d2
	 * @return
	 */
	public static double sub(double d1, double d2) {
		BigDecimal bd1 = new BigDecimal(Double.toString(d1));
		BigDecimal bd2 = new BigDecimal(Double.toString(d2));
		return bd1.subtract(bd2).doubleValue();
	}

	/**
	 * double 乘法
	 * 
	 * @param d1
	 * @param d2
	 * @return
	 */
	public static double mul(double d1, double d2) {
		BigDecimal bd1 = new BigDecimal(Double.toString(d1));
		BigDecimal bd2 = new BigDecimal(Double.toString(d2));
		return bd1.multiply(bd2).doubleValue();
	}

	/**
	 * double 除法
	 * 
	 * @param d1
	 * @param d2
	 * @param scale
	 *            四舍五入 小数点位数
	 * @return
	 */
	public static double div(double d1, double d2, int scale) {
		// 当然在此之前,你要判断分母是否为0,
		// 为0你可以根据实际需求做相应的处理

		BigDecimal bd1 = new BigDecimal(Double.toString(d1));
		BigDecimal bd2 = new BigDecimal(Double.toString(d2));
		return bd1.divide(bd2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
	}
}
package org.eredlab.g4.ccl.util;

/*
 *********



你的当前访问异常,请进行认证后继续阅读剩余内容。

分享到: