java ->大的數據運算(BigInteger)

大數據運算

BigInteger

  java中long型爲最大整數類型,對於超過long型的數據如何去表示呢.在Java的世界中,超過long型的整數已經不能被稱爲整數了,它們被封裝成BigInteger對象.在BigInteger類中,實現四則運算都是方法來實現,並非採用運算符.java

  BigInteger類的構造方法:ide

 BigInteger b = new BigInteger(str);大數據

  構造方法中,採用字符串的形式給出整數spa

四則運算代碼:對象

public static void main(String[] args) {ip

     //大數據封裝爲BigInteger對象ci

          BigInteger big1 = new BigInteger("12345678909876543210");字符串

          BigInteger big2 = new BigInteger("98765432101234567890");class

          //add實現加法運算循環

          BigInteger bigAdd = big1.add(big2);

          //subtract實現減法運算

          BigInteger bigSub = big1.subtract(big2);

          //multiply實現乘法運算

          BigInteger bigMul = big1.multiply(big2);

          //divide實現除法運算

          BigInteger bigDiv = big2.divide(big1);

}

BigDecimal

  在程序中執行下列代碼,會出現什麼問題?

    System.out.println(0.09 + 0.01);

    System.out.println(1.0 - 0.32);

    System.out.println(1.015 * 100);

    System.out.println(1.301 / 100);

 double和float類型在運算中很容易丟失精度,形成數據的不許確性,Java提供咱們BigDecimal類能夠實現浮點數據的高精度運算

   構造方法以下:

  BigDecimal b = new BigDecimal(str);

  建議浮點數據以字符串形式給出,由於參數結果是能夠預知的

  實現加法減法乘法代碼以下:(運算方法與BigInteger一致)

    public static void main(String[] args) {

          //大數據封裝爲BigDecimal對象

          BigDecimal big1 = new BigDecimal("0.09");

          BigDecimal big2 = new BigDecimal("0.01");

          //add實現加法運算

          BigDecimal bigAdd = big1.add(big2);

     

          BigDecimal big3 = new BigDecimal("1.0");

          BigDecimal big4 = new BigDecimal("0.32");

          //subtract實現減法運算

          BigDecimal bigSub = big3.subtract(big4);

         

          BigDecimal big5 = new BigDecimal("1.105");

          BigDecimal big6 = new BigDecimal("100");

          //multiply實現乘法運算

          BigDecimal bigMul = big5.multiply(big6);

  對於浮點數據的除法運算,和整數不一樣,可能出現無限不循環小數,所以須要對所須要的位數進行保留和選擇舍入模式

   BigDecimal b = big1.divide(big2,保留小數點後面幾位,舍入模式)

 // BigDecimal b = big1.divide.(big2,2,BigDecimal.ROUND_DOWN)

相關文章
相關標籤/搜索