本文實例講述了java中BigDecimal的操作方法。分享給大家供大家參考。具體分析如下:
由於double,float的精度不夠,因此在進行商業計算的時候要使用的BigDecimal。 BigDecimal物件創建如下:
複製程式碼如下:BigDecimal b = new BigDecimal("12.000001");
System.out.println(b);
輸出結果為:12.000001;
BigDecimal在創建的時候可以傳入String和double,但是最好使用String,至於原因看看如下程式碼就知道了:
複製程式碼如下:BigDecimal b = new BigDecimal("12.000001");
System.out.println(b);
BigDecimal c = new BigDecimal(12.01);
System.out.println(c);
運行結果為:
12.000001
12.0099999999999997868371792719699442386627197265625
可以看出在傳入double的時候精度會遺失。
BigDecimal其他操作如下:
複製程式碼代碼如下: //加法
public static BigDecimal add(String num1, String num2) {
BigDecimal bd1 = new BigDecimal(num1);
BigDecimal bd2 = new BigDecimal(num2);
return bd1.add(bd2);
}
//減法
public static BigDecimal subtract(String num1, String num2) {
BigDecimal bd1 = new BigDecimal(num1);
BigDecimal bd2 = new BigDecimal(num2);
return bd1.subtract(bd2);
}
//乘法
public static BigDecimal multiply(String num1, String num2) {
BigDecimal bd1 = new BigDecimal(num1);
BigDecimal bd2 = new BigDecimal(num2);
return bd1.multiply(bd2);
}
//除法
public static BigDecimal divide(String num1, String num2, int i) {
BigDecimal bd1 = new BigDecimal(num1);
BigDecimal bd2 = new BigDecimal(num2);
// i是要保留的位數, BigDecimal.ROUND_HALF_UP 表示四捨五入的規則
return bd1.divide(bd2, i, BigDecimal.ROUND_HALF_DOWN);
}
需要強調一下除法,第三個參數為是否四捨五入,
ROUND_HALF_DOWN表示遇5不進1,即1.5->1;
ROUND_HALF_UP表示遇5進1,即1.5->2;
但是有點要注意:
當我們使用ROUND_HALF_DOWN時複製程式碼程式碼如下:System.out.println(this.divide("67.75", "5",4));
System.out.println(this.divide("67.75", "5",1));
System.out.println("-------");
System.out.println(this.divide("67.751", "5",4));
System.out.println(this.divide("67.751", "5",1));
運行結果如下:
13.5500
13.5
-------
13.5502
13.6
我就納悶了,照道理第二個結果應該是13.5啊!怎麼成了13.6。後來經過多次測試,想了一下,這個四捨五入不是按照精度位後面移位與5做比較,而是按照精度位後的所有的數據與5做比較,也就是說:13.5500精確到一位,則用0.0500與5比較,而13.5502精確到一位,則用0.0502與5比較,比5大,所以就向上收。
希望本文所述對大家的Java程式設計有幫助。