Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数。在实际应用中,需要对更大或者更小的数进行运算和处理。float和double只能用来做科学计算或者是工程计算,在商业计算中要用java.math.BigDecimal。BigDecimal所创建的是对象,我们不能使用传统的+、-、*、/等算术运算符直接对其对象进行数学运算,而必须调用其相对应的方法。方法中的参数也必须是BigDecimal的对象。构造器是类的特殊方法,专门用来创建对象,特别是带有参数的对象。
1、BigDecimal中:相加(add)、相减(subtract)、相乘(multiply)、相除(divide)
public static void main(String[] args){
BigDecimal num1 = new BigDecimal("2");
BigDecimal num2 = new BigDecimal("4");
System.out.println("相加:"+num2.add(num1));
System.out.println("相减:"+num2.subtract(num1));
System.out.println("相乘:"+num2.multiply(num1));
System.out.println("相除:"+num2.divide(num1));
}
2、BigDecimal的compareTo比较模式,常用比较方法
public static void main(String[] args){
BigDecimal num1 = new BigDecimal(0.1);
BigDecimal num2 = new BigDecimal(0.2);
if(num1.compareTo(num2) == 1){
System.out.println(num1.compareTo(num2));// 1 大于
}
if(num1.compareTo(num2) == 0){
System.out.println(num1.compareTo(num2));// 0 等于
}
if(num1.compareTo(num2) == -1){
System.out.println(num1.compareTo(num2));// -1 小于
}
boolean flag1 = num1.compareTo(num2) > 0; // 大于
boolean flag2 num1.compareTo(num2) < 0; // 小于
boolean flag3 num1.compareTo(num2) == 0;// 等于
boolean flag4 num1.compareTo(num2) >= 0;// 大于等于
boolean flag5 num1.compareTo(num2) <= 0;// 小于等于
}
3、BigDecimal的八种舍入模式
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)向最接近的数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。
4、BigDecimal进阶知识
https://blog.csdn.net/weixin_49114503/article/details/129056256