BigDecimal使用ROUND_HALF_UP進行四捨五入

weixin_34378969發表於2018-03-31
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);

http://stackoverflow.com/questions/12460482/how-to-round-0-745-to-0-75-using-bigdecimal-round-half-up

相關文章