最近在做项目时,有一个保留两位小数的需求,该需求要求不四舍五入,即将两位小数后的数直接舍弃,网上查了BigDecimal的用法,发现ROUND_ROUND_DOWN这种舍弃方式符合需求,故使用该方式.
double money = 0.030;
money = new BigDecimal(money).setScale(2,BigDecimal.ROUND_DOWN).doubleValue();
用以上方式进行保留两位小数的操作,发现money变成了0.29(预期结果是0.03)
网上找了许多资料,找到如下解决方法:
1 BigDecimal(double val)
Translates a double into a BigDecimal.
-----------------------------------------------------
2 BigDecimal(String val)
Translates the String repre sentation of a BigDecimal into a BigDecimal.
这是BigDecimal的两个构造方法,我使用的是第一个构造方法,导致丢失精度。
使用第二个构造函数即可让ROUND_DOWN正常工作
money = new BigDecimal(""+money).setScale(2,BigDecimal.ROUND_DOWN).doubleValue();