一:类应用场景
商用系统在计算金额这类小数时,由于Double精度缺失的问题,往往会发生不可预知的情况,故而会使用BigDecimal。
二:构造函数
此类的构造函数很多,此处着重记录一个构造函数:
1. BigDecimal(String s):此处的s并不是适用于所有的字符串,仅适用于数字类型的字符串。例如:
BigDecimal bd1 = new BigDecimal("ssss");//NumberFormatException异常
BigDecimal bd2 = new BigDecimal("2.256");//正确方式
三:常用方法
1. 加减乘除
加法:add(BigDecimal bd)
减法:subtract(BigDecimal bd)
乘法:multiply(BigDecimal bd)
除法:divide(BigDecimal bd)
2. 舍入模式
1、ROUND_UP 远离零的舍入模式:使用这个模式,得到的结果的模(俗称绝对值)总是会变大,可执行代码:
String testNumber = "1.2564";
BigDecimal bd3 = new BigDecimal(testNumber);
BigDecimal bd4 = bd3.setScale(3,BigDecimal.ROUND_UP);
System.out.println(bd4);
上述代码输出结果为1.257。如果将testNumber改为“-1.2564”,其输出结果将是-1.257。从此可以看出,此种模式总会向着远离坐标原点的方向舍入。
2、ROUND_DOWN 接近零的舍入模式:这个模式和ROUND_UP恰恰相反,得到的结果的模总是会变小,不再赘述。
3、ROUND_CEILING 接近正无穷大的舍入模式:使用这个模式,得到的结果总会向着正无穷大的方向移动,不啰嗦,上代码:
String testNumber = "1.2567";
BigDecimal bd3 = new BigDecimal(testNumber);
BigDecimal bd4 = bd3.setScale(3,BigDecimal.ROUND_CEILING);
上述代码输出结果为1.257。如果将testNumber改为“-1.2564”,其输出结果将是-1.256。从此可以看出,此种模式总会向着正无穷的方向舍入。
4、ROUND_FLOOR 接近负无穷大的舍入模式:这个模式和ROUND_CEILING恰恰相反,舍入结果总会向着负无穷的方向舍入,不再赘述。
5、ROUND_HALF_UP 四舍五入:我们观念中的四舍五入模式,假定保留三位小数,-1.2564–>-1.256;-1.2565–>-1.257;若是正数的话亦如此,是最好理解的一种模式。
6、ROUND_HALF_DOWN 五舍六入:和ROUND_HALF_UP类似,只不过这个模式中的5是舍去的情况:-1.2565–>-1.256;-1.2566–>-1.257。
7、ROUND_HALF_EVEN 四舍六入,五入偶数:4舍去,6进位,5总是向偶数舍入;
ROUND_HALF_UP和ROUND_HALF_DOWN两种模式相同之处在于:4舍去,6进位;不同之处在于5的判断:若5选择进位,则为ROUND_HALF_UP,若5选择舍去,则为ROUND_HALF_DOWN。
8、ROUND_UNNECESSARY:(待了解)
四: 注意事项
1. 构造函数中,BigDecimal(Double d)最好不要使用,会发生不可预知的结果,最好使用BigDecimal(String s)这个构造函数;
BigDecimal bd5 = new BigDecimal(156.1);
System.out.println(bd5);//输出156.099999999999994315658113919198513031005859375
- BigDecimal这个类是不可变的,类似String。
BigDecimal bd1 = new BigDecimal("2.3");
BigDecimal bd2 = new BigDecimal(0);
bd2.add(bd1);
System.out.println(bd2);//输出0