我是靠谱客的博主 体贴睫毛,最近开发中收集的这篇文章主要介绍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);

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

最后

以上就是体贴睫毛为你收集整理的BigDecimal使用ROUND_HALF_UP进行四舍五入的全部内容,希望文章能够帮你解决BigDecimal使用ROUND_HALF_UP进行四舍五入所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(71)

评论列表共有 0 条评论

立即
投稿
返回
顶部