今天翻项目源码时发现idea的编译警告信息。
关于BigDecimal的进退位的精度损失的简单处理办法
意识到精度损失的严重性,特意做了一下简单的测试。关于BigDecimal的进退位的精度损失的简单处理办法
上图发现将参数设置为BigDecimal.ROUND_HALF_UP,第三位小数并未准确进位,将其转化为字符串打印出来:
关于BigDecimal的进退位的精度损失的简单处理办法
将其转化成字符串之后,小数两位之后并不精确,BigDecimal.ROUND_HALF_UP以1.154进行取舍导致出现错误数值。
尝试使用BigDecimal.valueOf()方式实例化BigDecimal对象。
关于BigDecimal的进退位的精度损失的简单处理办法
数值正确。再看一下valueOf()方法打印出来的字符串:
关于BigDecimal的进退位的精度损失的简单处理办法
这样进退位就会得到准确的数值。
关于BigDecimal的进退位的精度损失的简单处理办法
为防止代码冗余,可以将其抽离出一个初始化方法,从而不影响Lombok注解的使用。double或BigDecimal属性以数据库为准。
关于BigDecimal的进退位的精度损失的简单处理办法

相关文章: