BigDecimal 保留两位小数:截取 和 四舍五入
BigDecimal.setScale()方法用于格式化小数点
setScale(2);//表示保留2位小数,默认用四舍五入方式
setScale(2,BigDecimal.ROUND_DOWN);//直接删除多余的小数位 11.116约=11.11
setScale(2,BigDecimal.ROUND_UP);//临近位非零,则直接进位;临近位为零,不进位。11.114约=11.12
setScale(2,BigDecimal.ROUND_HALF_UP);//四舍五入 2.335约=2.33,2.3351约=2.34
setScaler(2,BigDecimal.ROUND_HALF_DOWN);//四舍五入;2.335约=2.33,2.3351约=2.34,11.117约11.12
注:原因是,计算机解析一个浮点数据时,和原始数据有偏差,如:
2.335 =2.33499999999999996447286321199499070644378662109375;
2.3350=2.33499999999999996447286321199499070644378662109375;
2.3351=2.335100000000000175504055732744745910167694091796875
疑问:ROUND_HALF_UP和ROUND_HALF_DOWN的差别?