天天看點

Java的double的精度問題以及解決方案

        在java中,使用double進行運算,有時會出現精度丢失的問題,值會有那麼0.00000***1偏差的偏差,導緻比對校驗常常出現問題

解決方案如下:

/**  
     * 對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 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 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 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 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(); 
    } 
           

這樣,計算double類型的資料計算問題就可以處理了。

另外補充一下 JavaScript 四舍五入的方法:

//保留 2 位小數
Math.round(totalAmount*100)/100
function formatFloat(src, pos){
  return Math.round(src*Math.pow(10, pos))/Math.pow(10, pos);
}