BigDemical用float或者double丟失精度問題

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.74ui

 

運行以上代碼能夠看到,1.745四捨五入的結果是1.75,0.745四捨五入的結果是0.74。spa

緣由:
使用參數爲float或double的BigDecimal建立對象會丟失精度。所以強烈建議不要使用參數爲float或double的BigDecimal建立對象。.net

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);
————————————————

原文連接:https://blog.csdn.net/zongzhankui/article/details/79591294blog

相關文章
相關標籤/搜索