本文主要是介绍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出现过程
在计算手续费收取比例的时候同事直接将BigDecimal类型使用divide(除法运算)之后的数据做 multiply 乘法运算,然后我将投放金额设为10亿,手续费设为六十六万的时候,此时比例0.000666666… 然后乘以十,所以导致报此错误。
然后我结合真实场景并和同事沟通后,选择将除出来的数截取小数点后四位 不进行任何处理
BUG解决
FeeAmountt().divide(LoanAmount(),4,BigDecimal.ROUND_DOWN).multiply(BigDecimal.valueOf(100)));
BigDecimal在做divide运算时加上 保留小数位 和 保留规则
保留规则有如下:
- ROUND_UP :始终对非零舍弃部分前面的数字加 1 (直接进1)
- ROUND_DOWN :直接去除后面的数(直接舍去)
- ROUND_CEILING :如果结果为正,则舍入行为类似于 RoundingMode.UP;如果结果为负,则舍入行为类似于RoundingMode.DOWN(当正数时直接进一,当负数时舍去)
- ROUND_FLOOR :如果结果为正,则舍入行为类似于 RoundingMode.DOWN;如果结果为负,则舍入行为类似于RoundingMode.UP(当正数时舍去,当负数时进一)
- HALF_UP:如果被舍弃部分 >= 0.5,则舍入行为同 RoundingMode.UP;否则舍入行为同RoundingMode.DOWN(四舍五入)
- HALF_DOWN:如果被舍弃部分 > 0.5,则舍入行为同 RoundingMode.UP;否则舍入行为同RoundingMode.DOWN。(五舍六入)
- HALF_EVEN:如果舍弃部分左边的数字为奇数,则舍入行为同 RoundingMode.HALF_UP;如果为偶数,则舍入行为同RoundingMode.HALF_DOWN(五舍六入,奇数四舍五入)
- UNNECESSARY:计算结果是精确的,不需要舍入,否则抛出 ArithmeticException
建议在BigDecimal类型使用divide方法时都填上相对应的参数和取舍规则,以防BUG !!
这篇关于Non-terminating decimal expansion; no exact representable decimal result 问题解决的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!