工作过程中遇到账目不平的bug, 记录如下:
开始认为 BigDecimal.ROUND_HALF_DOWN只看要求精度后面的第一位是否小于等于5, 如果小于等于5,则舍弃精度后面的数, 这其实是不完全对的。
其实还需要看要求精度后面的第二位(如果存在)是否大于等于5, 如果是则会进位,需进位后在进行操作。
举例:
如果bigDecimal值为 1.12345, 要求精度为四位-bigDecimal.setScale(4,BigDecimal.ROUND_HALF_DOWN),则返回值为1.1234;
如果bigDecimal值为1.123455, 要求精度为四位-bigDecimal.setScale(4,BigDecimal.ROUND_HALF_DOWN),则返回值为1.1235;
public class BigDecimalTest {
private static BigDecimal bigDecimal;
public static void main(String[] args) {
test1(new BigDecimal("1.12345"));
System.out.println("-------------------------");
test1(new BigDecimal("1.123455"));
}
private static void test1(BigDecimal numb) {
bigDecimal = numb;
System.out.println(numb);
BigDecimal setScale = numb.setScale(4,BigDecimal.ROUND_HALF_DOWN);
System.out.println(setScale);
BigDecimal setScale2 = numb.setScale(4,BigDecimal.ROUND_HALF_UP);
System.out.println(setScale2 );
}
}
结果: