有次做一個for迴圈(1000次左右),做的事情也是很簡單的事情,就是 Double testValue = (long類型 / 8 ) * long類型 的一些加減乘除操作,
但是總是出現一些資料算的不對,大部分出現資料丟失了,出現了這樣一個情況 (100/8)* 60 本來等於750 ,在for中卻是720 。
寫個Uitls類吧,使用BigDecimal處理。這個Utils可以繼續add的。
package com.sencloud.dh.core.utils;import java.math.BigDecimal;/** * 演算法工具類 * <一句話功能簡述> * <功能詳細描述> * * @author xutianlong * @version [版本號碼, Aug 9, 2013] * @see [相關類/方法] * @since [產品/模組版本] */public class AlgorithmUtil{ private static final int DEF_DIV_SCALE = 10; /** * * 兩個Double數相加 * * * @param v1 * * @param v2 * * @return Double */ public static Double add(Double v1, Double v2) { BigDecimal b1 = new BigDecimal(v1.toString()); BigDecimal b2 = new BigDecimal(v2.toString()); return b1.add(b2).doubleValue(); } /** * * 兩個Double數相加 * * * @param v1 * * @param v2 * * @return Double */ public static Double add(Long v1, Long v2) { BigDecimal b1 = new BigDecimal(v1.toString()); BigDecimal b2 = new BigDecimal(v2.toString()); return b1.add(b2).doubleValue(); } /** * * 兩個Double數相減 * * * @param v1 * * @param v2 * * @return Double */ public static Double sub(Double v1, Double v2) { BigDecimal b1 = new BigDecimal(v1.toString()); BigDecimal b2 = new BigDecimal(v2.toString()); return b1.subtract(b2).doubleValue(); } /** * * 兩個Double數相乘 * * * @param v1 * * @param v2 * * @return Double */ public static Double mul(Double v1, Double v2) { BigDecimal b1 = new BigDecimal(v1.toString()); BigDecimal b2 = new BigDecimal(v2.toString()); return b1.multiply(b2).doubleValue(); } /** * * 兩個數相乘 * * * @param v1 * * @param v2 * * @return Double */ public static Double mul(Double v1, Long v2) { BigDecimal b1 = new BigDecimal(v1.toString()); BigDecimal b2 = new BigDecimal(v2.toString()); return b1.multiply(b2).doubleValue(); } /** * * 兩個Double數相除 * * * @param v1 * * @param v2 * * @return Double */ public static Double div(Double v1, Double v2) { BigDecimal b1 = new BigDecimal(v1.toString()); BigDecimal b2 = new BigDecimal(v2.toString()); return b1.divide(b2, DEF_DIV_SCALE, BigDecimal.ROUND_HALF_UP).doubleValue(); } /** * * 兩個Double數相除 * * * @param v1 * * @param v2 * * @return Double */ public static Double div(Double v1, Long v2) { BigDecimal b1 = new BigDecimal(v1.toString()); BigDecimal b2 = new BigDecimal(v2.toString()); return b1.divide(b2, DEF_DIV_SCALE, BigDecimal.ROUND_HALF_UP).doubleValue(); } /** * * 兩個Long數相除 * * * @param v1 * * @param v2 * * @return Double */ public static Double div(Long v1, Long v2) { BigDecimal b1 = new BigDecimal(v1.toString()); BigDecimal b2 = new BigDecimal(v2.toString()); return b1.divide(b2, DEF_DIV_SCALE, BigDecimal.ROUND_HALF_UP).doubleValue(); } /** * * 兩個Double數相除,並保留scale位小數 * * * @param v1 * * @param v2 * * @param scale * * @return Double */ public static Double div(Double v1, Double v2, int scale) { if (scale < 0) { throw new IllegalArgumentException("The scale must be a positive integer or zero"); } BigDecimal b1 = new BigDecimal(v1.toString()); BigDecimal b2 = new BigDecimal(v2.toString()); return b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue(); }}