Java BigDecimal類的應用和留意事項。本站提示廣大學習愛好者:(Java BigDecimal類的應用和留意事項)文章只能為提供參考,不一定能成為您想要的結果。以下是Java BigDecimal類的應用和留意事項正文
BigDecimal簡介
JDK文檔(中文)中的說明以下:
弗成變的、隨意率性精度的有符號十進制數。BigDecimal 由隨意率性精度的整數非標度值 和 32 位的整數標度 (scale) 構成。假如為零或負數,則標度是小數點後的位數。假如為正數,則將該數的非標度值乘以 10 的負 scale 次冪。是以,BigDecimal 表現的數值是 (unscaledValue × 10-scale)。
詳細說明
1.“BigDecimal 對象的值是弗成變的”。這點在BigDecimal 對象的運算函數中表示了該特征:
BigDecimal a = new BigDecimal("1.22");
System.out.println("construct with a String value: " + a);
BigDecimal b = new BigDecimal("2.22");
a.add(b);
System.out.println("a plus b is : " + a);
我們很輕易會以為會輸入:
construct with a Stringvalue: 1.22
a plus b is :3.44
但現實上a plus b is : 1.22
2.“BigDecimal 由隨意率性精度的整數非標度值 和 32 位的整數標度 (scale) 構成。假如標度值為零或負數,則標度是小數點後的位數”。這句話可以如許看:
例如:-12 和 13.412
表現為:-12 × 10-0 和13412 × 10-3
這裡用(非標度值 和 標度)表現分離為:[-12, 0]和[13412, 3]
3.“假如標度值為正數,則將該數的非標度值乘以 10 的負 scale 次冪”。這句話可以如許看:
例如:120.00
該值表現為:12000 × 10-2
這裡用(非標度值 和 標度)表現分離為:[12000, 2]
這裡標度的值仍然為負數2,然則停止停止上面操作:
BigDecimal amount = new BigDecimal("-120.00");
//前往數值上等於此小數,但從該表現情勢移除一切尾部零的 BigDecimal。
amount = amount.stripTrailingZeros();
該值表現為:12 × 10-(-1)
這裡用(非標度值 和 標度)表現分離為:[12, -1]
應用留意事項
1.結構函數
BigDecimal aDouble =new BigDecimal(1.22);
System.out.println("construct with a double value: " + aDouble);
BigDecimal aString = new BigDecimal("1.22");
System.out.println("construct with a String value: " + aString);
輸入成果以下:
construct with a doublevalue:1.2199999999999999733546474089962430298328399658203125
construct with a String value: 1.22
JDK的描寫:
a)參數類型為double的結構辦法的成果有必定的弗成預知性。有人能夠以為在Java中寫入newBigDecimal(0.1)所創立的BigDecimal正好等於 0.1(非標度值 1,其標度為 1),然則它現實上等於0.1000000000000000055511151231257827021181583404541015625。這是由於0.1沒法精確地表現為 double(或許說關於該情形,不克不及表現為任何無限長度的二進制小數)。如許,傳入到結構辦法的值不會正好等於 0.1(固然外面上等於該值)。
b)另外一方面,String 結構辦法是完整可預知的:寫入 newBigDecimal("0.1") 將創立一個 BigDecimal,它正好等於預期的 0.1。是以,比擬而言,平日建議優先應用String結構辦法。
c)當double必需用作BigDecimal的源時,請留意,此結構辦法供給了一個精確轉換;它不供給與以下操作雷同的成果:先應用Double.toString(double)辦法,然後應用BigDecimal(String)結構辦法。將double轉換為String,也能夠應用String的static辦法:String.valueOf(double)。
2.運算操作。加減乘除其實終究都前往的是一個新的BigDecimal對象,由於BigDecimal都是弗成變的(immutable)的,在停止每步運算時,都邑發生一個新的對象,所以a.add(b);固然做了加法操作,然則a並沒有保留加操作後的值,准確的用法應當是a=a.add(b);
例子:
剖斷BigDecimal 對象能否為整數:
private boolean isIntegerValue(BigDecimal bd) {
return bd.signum() == 0 || bd.scale() <= 0 || bd.stripTrailingZeros().scale() <= 0;
}
為何要如許做,請測試下上面這個例子:
BigDecimal amount = new BigDecimal("-120.00");//請分離測驗考試"0", "0.00", "1.00","10.00"和"10.10"
System.out.println(amount.signum());//正負
System.out.println(amount.scale()); //標度
System.out.println(amount.stripTrailingZeros().scale());//去零後的標度
參考:類 BigDecimal