1. 程式人生 > 程式設計 >java.math包下計算浮點數和整數的類的例項

java.math包下計算浮點數和整數的類的例項

java.math包提供了java中的數學類。包括基本的浮點庫、複雜運算以及任意精度的資料運算

提供用於執行任意精度整數演算法 (BigInteger) 和任意精度小數演算法 (BigDecimal) 的類。BigInteger 除提供任意精度之外,它類似於 Java 的基本整數型別,因此在 BigInteger 上執行的操作不產生溢位,也不會丟失精度。除標準演算法操作外,BigInteger 還提供模 (modular) 演算法、GCD 計算、基本 (primality) 測試、素數生成、位處理以及一些其他操作。 BigDecimal 提供適用於貨幣計算和類似計算的任意精度的有符號十進位制數字。BigDecimal 允許使用者對舍入行為進行完全控制,並允許使用者選擇所有八個舍入模式。

1. BigDecimal

不可變的、任意精度的有符號十進位制數。BigDecimal 由任意精度的整數非標度值 和 32 位的整數標度 (scale) 組成。如果為零或正數,則標度是小數點後的位數。如果為負數,則將該數的非標度值乘以 10 的負 scale 次冪。因此,BigDecimal 表示的數值是 (unscaledValue × 10-scale)。

下面通過一些例子給大家詳細介紹下java.math包下計算浮點數和整數的類,一起看看吧

(1)BigIntege:實現任意精度的整數運算。
(2)BigDecimal:實現任意精度的浮點運算。

例如:

使用BigDecimal進行浮點數比較

import java.math.BigDecimal;
public class HelloWorld{
 public static void main(String[] args){
  BigDecimal a=BigDecimal.valueOf(1.0);
  a=a.subtract(BigDecimal.valueOf(0.1)); //subtract:減去
  a=a.subtract(BigDecimal.valueOf(0.1));
  a=a.subtract(BigDecimal.valueOf(0.1));
  a=a.subtract(BigDecimal.valueOf(0.1));
  a=a.subtract(BigDecimal.valueOf(0.1));
  System.out.println(a); //輸出:0.5
  System.out.println(1.0-0.1-0.1-0.1-0.1-0.1); //輸出:0.5000000000000001

  BigDecimal b=BigDecimal.valueOf(0.1);
  BigDecimal c=BigDecimal.valueOf(1.0/10.0);
  System.out.println(b==c); //false
  System.out.println(b.equals(c)); //true
 }
}

總結

到此這篇關於java.math包下計算浮點數和整數的類的例項的文章就介紹到這了,更多相關java 計算浮點數和整數內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!