BigDecimal使用ROUND_HALF_UP進行四捨五入

BigDecimal bdTest = new BigDecimal(1.745);
BigDecimal bdTest1 = new BigDecimal(0.745);
bdTest = bdTest.setScale(2, BigDecimal.ROUND_HALF_UP);
bdTest1 = bdTest1.setScale(2, BigDecimal.ROUND_HALF_UP);
System.out.println("bdTest:" + bdTest); // 1.75
System.out.println("bdTest1:" + bdTest1); // 0.74

運行以上代碼可以看到,1.745四捨五入的結果是1.750.745四捨五入的結果是0.74

原因:
使用參數爲float或double的BigDecimal創建對象會丟失精度。因此強烈建議不要使用參數爲float或double的BigDecimal創建對象。

System.out.println(new BigDecimal(1.745)); // 1.74500000000000010658141036401502788066864013671875
System.out.println(new BigDecimal(0.745)); // 0.74499999999999999555910790149937383830547332763671875

解決辦法:

  1. 使用BigDecimal(String val)的構造方法創建對象
    new BigDecimal("1.745");
    new BigDecimal("0.745");
  2. 使用使用BigDecimal的valueOf(double val)方法創建對象
    BigDecimal.valueOf(1.745);
    BigDecimal.valueOf(0.745);



作者:Java_Explorer
鏈接:https://www.jianshu.com/p/4737a066d93e
來源:簡書
著作權歸作者所有。商業轉載請聯繫作者獲得授權,非商業轉載請註明出處。

發佈了4 篇原創文章 · 獲贊 3 · 訪問量 8079
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章