程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> Java BigDecimal類的應用和留意事項

Java BigDecimal類的應用和留意事項

編輯:關於JAVA

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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved