问题出现原因: 当我们使用BigDecimal做除法divide时,可能出现这个异常。
出现场景:
BigDecimal sales;
BigDecimal GMV;
bug代码:
BigDecimal rate = (sales!=null && GMV != null)?sales.divide(GMV):BigDecimal.ZERO;
解决方案:
(sales!=null && GMV != null)?sales.divide(GMV,4, RoundingMode.HALF_UP):BigDecimal.ZERO
说明:加上精确到小数点位数4位, 以及其余小数位向上取整RoundingMode.HALF_UP, 即可解决。
本文介绍在使用BigDecimal进行除法运算时可能遇到的异常,并提供了解决方案。通过指定小数点后四位并采用HALF_UP模式进行四舍五入,可以避免精度问题。
4748

被折叠的 条评论
为什么被折叠?



