1、BigDecimal的介绍
BigDecimal是Java在java.math包中提供的线程安全的API类。BigDecimal是Java中用于表示任意精度数字的类,它可以表示无限长度的小数,BigDecimal 通常支持任意位数的小数部分,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数,但在实际应用中,可能需要对更大或者更小的数进行运算和处理。一般情况下,对于那些不需要准确计算精度的数字,我们可以直接使用Float和Double处理,但是Double.valueOf(String) 和Float.valueOf(String)会丢失精度。所以开发中,如果我们需要精确计算的结果,则必须使用BigDecimal类来操作。
2、常用构造方法和使用方法
1、构造方法
- BigDecimal(int val)
- BigDecimal(double val)
- BigDecimal(float val) 不推荐使用
- BigDecimal(String val) 推荐使用
2、常用方法
public static void main(String[] args) {
BigDecimal b1 = new BigDecimal("1");
BigDecimal b2 = new BigDecimal("2");
BigDecimal b3 = new BigDecimal("4");
System.out.println("相加:"+b1.add(b2));
System.out.println("相减:"+b1.subtract(b2));
System.out.println("相乘:"+b2.multiply(b3));
System.out.println("相除:"+b2.divide(b3));
BigDecimal divide = b1.subtract(b2);
System.out.println("取绝对值: "+divide.abs());
System.out.println("将BigDecimal对象中的值转换成双精度数: "+b1.doubleValue());
System.out.println("将BigDecimal对象中的值转换成单精度数: "+b1.floatValue());
//比较大小 返回int类型:0(相等) 1(大于) -1(小于)
System.out.println("比较: "+b1.compareTo(b2));
}
相加:3
相减:-1
相乘:8
相除:0.5
取绝对值: 1
将BigDecimal对象中的值转换成双精度数: 1.0
将BigDecimal对象中的值转换成单精度数: 1.0
比较: -1
3、BigDecimal的八种舍入模式
BigDecimal.setScale()方法用于格式化小数点
setScale(1)表示保留一位小数,默认用四舍五入方式
setScale(1,BigDecimal.ROUND_DOWN)直接删除多余的小数位,如2.35会变成2.3
setScale(1,BigDecimal.ROUND_UP)进位处理,2.35变成2.4
setScale(1,BigDecimal.ROUND_HALF_UP)四舍五入,2.35变成2.4
setScaler(1,BigDecimal.ROUND_HALF_DOWN)四舍五入,2.35变成2.3,如果是5则向下舍
setScaler(1,BigDecimal.ROUND_CEILING)接近正无穷大的舍入
setScaler(1,BigDecimal.ROUND_FLOOR)接近负无穷大的舍入,数字>0和ROUND_UP作用一样,数字<0和ROUND_DOWN作用一样
setScaler(1,BigDecimal.ROUND_HALF_EVEN)向最接近的数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。