由於double,float的精度不夠,因此在進行商業計算的時候要使用的BigDecimal。BigDecimal對象創建如下:
複製代碼 代碼如下:BigDecimal b = new BigDecimal("12.000001");
tln(b);
輸出結果爲:12.000001;
BigDecimal在創建的時候可以傳入String和double,但是最好使用String,至於原因看看如下代碼就知道了:
複製代碼 代碼如下:BigDecimal b = new BigDecimal("12.000001");
tln(b);
BigDecimal c = new BigDecimal(12.01);
tln(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 (bd2);
}
//減法
public static BigDecimal subtract(String num1, String num2) {
BigDecimal bd1 = new BigDecimal(num1);
BigDecimal bd2 = new BigDecimal(num2);
return ract(bd2);
}
//乘法
public static BigDecimal multiply(String num1, String num2) {
BigDecimal bd1 = new BigDecimal(num1);
BigDecimal bd2 = new BigDecimal(num2);
return iply(bd2);
}
//除法
public static BigDecimal divide(String num1, String num2, int i) {
BigDecimal bd1 = new BigDecimal(num1);
BigDecimal bd2 = new BigDecimal(num2);
// i是要保留的.位數, D_HALF_UP 表示四捨五入的規則
return de(bd2, i, D_HALF_DOWN);
}
需要強調一下除法,第三個參數爲是否四捨五入,
ROUND_HALF_DOWN表示遇5不進1,即1.5->1;
ROUND_HALF_UP表示遇5進1,即1.5->2;
但是有點需要注意:
當我們使用ROUND_HALF_DOWN時
複製代碼 代碼如下:tln(de("67.75", "5",4));
tln(de("67.75", "5",1));
tln("-------");
tln(de("67.751", "5",4));
tln(de("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程序設計有所幫助。