Non-terminating decimal expansion; no exact representable decimal result 问题解决

今天帮同事测试代码的时候,发现了一个bug问题,bug如下:

BUG

java.lang.ArithmeticException: Non-terminating decimal expansion; no exact representable decimal result.
bug

Bug出现过程

在计算手续费收取比例的时候同事直接将BigDecimal类型使用divide(除法运算)之后的数据做 multiply 乘法运算,然后我将投放金额设为10亿,手续费设为六十六万的时候,此时比例0.000666666… 然后乘以十,所以导致报此错误。
然后我结合真实场景并和同事沟通后,选择将除出来的数截取小数点后四位 不进行任何处理

BUG解决

FeeAmountt().divide(LoanAmount(),4,BigDecimal.ROUND_DOWN).multiply(BigDecimal.valueOf(100)));

BigDecimal在做divide运算时加上 保留小数位 和 保留规则
保留规则有如下:
保留规则

  1. ROUND_UP :始终对非零舍弃部分前面的数字加 1 (直接进1
  2. ROUND_DOWN :直接去除后面的数(直接舍去
  3. ROUND_CEILING :如果结果为正,则舍入行为类似于 RoundingMode.UP;如果结果为负,则舍入行为类似于RoundingMode.DOWN(当正数时直接进一,当负数时舍去
  4. ROUND_FLOOR :如果结果为正,则舍入行为类似于 RoundingMode.DOWN;如果结果为负,则舍入行为类似于RoundingMode.UP(当正数时舍去,当负数时进一
  5. HALF_UP:如果被舍弃部分 >= 0.5,则舍入行为同 RoundingMode.UP;否则舍入行为同RoundingMode.DOWN(四舍五入
  6. HALF_DOWN:如果被舍弃部分 > 0.5,则舍入行为同 RoundingMode.UP;否则舍入行为同RoundingMode.DOWN。(五舍六入
  7. HALF_EVEN:如果舍弃部分左边的数字为奇数,则舍入行为同 RoundingMode.HALF_UP;如果为偶数,则舍入行为同RoundingMode.HALF_DOWN(五舍六入,奇数四舍五入
  8. UNNECESSARY:计算结果是精确的,不需要舍入,否则抛出 ArithmeticException

建议在BigDecimal类型使用divide方法时都填上相对应的参数和取舍规则,以防BUG !!

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值