java中BigDecimal的操作方法詳解

由於double,float的精度不夠,因此在進行商業計算的時候要使用的BigDecimal。BigDecimal對象創建如下:

java中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程序設計有所幫助。