BUG今天帮同事测试代码的时候,发现了一个bug问题,bug如下:
Bug出现过程java.lang.ArithmeticException: Non-terminating decimal expansion; no exact representable decimal result.
在计算手续费收取比例的时候同事直接将BigDecimal类型使用divide(除法运算)之后的数据做 multiply 乘法运算,然后我将投放金额设为10亿,手续费设为六十六万的时候,此时比例0.000666666… 然后乘以十,所以导致报此错误。
然后我结合真实场景并和同事沟通后,选择将除出来的数截取小数点后四位 不进行任何处理
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 !!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)