出现 Non-terminating decimal expansion; no exact representable decimal result 问题的解决方法
发布日期:2021-06-29 21:09:36 浏览次数:2 分类:技术文章

本文共 665 字,大约阅读时间需要 2 分钟。

代码中使用了 BigDecimal 做精确计算,在做除法时,系统抛出 “ Non-terminating decimal expansion; no exact representable decimal result”。

1 分析

BigDecimal 是不可变的、任意精度的有符号十进制数,所以可以做精确计算。但在除法中,准确的商可能是一个无限长的十进制扩展;例如,1 除以 3 所得的商。我们在做除法时,没有指定舍入模式,并且无法表示为准确的结果,因此抛出了这个异常(java.lang.ArithmeticException)。

2 解决

可以在 divide() 方法中传入 MathContext 对象或 RoundingMode 对象,指定精度和舍入模式,这样就不会再抛错咯O(∩_∩)O哈哈~

在任何情况下,可以为舍入控制提供八种舍入模式。

RoundingMode 对象提供了以下八种舍入模式:

常量名 说明
CEILING 向正无限大方向舍入。
DOWN 向零方向舍入。
FLOOR 向负无限大方向舍入。
HALF_DOWN 向最接近数字方向舍入,如果与两个相邻数字的距离相等,则向下舍入。
HALF_EVEN 向最接近数字方向舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。
HALF_UP 向最接近数字方向舍入,如果与两个相邻数字的距离相等,则向上舍入。
UNNECESSARY 断言具有精确结果。

举例如下:

舍入模式举例

我们用的比较多的舍入模式是 HALF_UP,也就是俗称的四舍五入啦O(∩_∩)O哈哈~

转载地址:https://deniro.blog.csdn.net/article/details/79164847 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:使用 Navicat for MySQL 执行 SQL 语句时,出现 out of memory 问题的解决方法
下一篇:说说在 log4j 中如何把日志记录到不同的文件中

发表评论

最新留言

路过,博主的博客真漂亮。。
[***.116.15.85]2024年04月17日 14时25分41秒