一、BigDecimal概述
Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数,但在实际应用中,可能需要对更大或者更小的数进行运算和处理。
一般情况下,对于那些不需要准确计算精度的数字,我们可以直接使用Float和Double处理,但是Double.valueOf(String) 和Float.valueOf(String)会丢失精度。所以开发中,如果我们需要精确计算的结果,则必须使用BigDecimal类来操作。
BigDecimal所创建的是对象,故我们不能使用传统的+、-、*、/等算术运算符直接对其对象进行数学运算,而必须调用其相对应的方法。方法中的参数也必须是BigDecimal的对象。构造器是类的特殊方法,专门用来创建对象,特别是带有参数的对象。
二、BigDecimal常用构造函数
BigDecimal(int) 创建一个具有参数所指定整数值的对象。
BigDecimal(double) 创建一个具有参数所指定双精度值的对象。 //不推荐使用
BigDecimal(long) 创建一个具有参数所指定长整数值的对象。
BigDecimal(String) 创建一个具有参数所指定以字符串表示的数值的对象。//推荐使用
三、BigDecimal加减乘除运算及基本方法
-
add(BigDecimal) BigDecimal对象中的值相加,返回BigDecimal对象
-
subtract(BigDecimal) BigDecimal对象中的值相减,返回BigDecimal对象
-
multiply(BigDecimal) BigDecimal对象中的值相乘,返回BigDecimal对象
-
divide(BigDecimal) BigDecimal对象中的值相除,返回BigDecimal对象,使用除法函数在divide的时候要设置各种参数,要精确的小数位数和舍入模式,不然会出现报错
x.divide(z, 5, BigDecimal.ROUND_HALF_UP);
ROUND_HALF_UP:向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。如果舍弃部分 >= 0.5,则舍入行为与 ROUND_UP 相同;否则舍入行为与 ROUND_DOWN 相同。注意,这是我们大多数人在小学时就学过的舍入模式(四舍五入)。关于详细的八种舍入模式可以参考以下博客BigDecimal加减乘除计算_haiyinshushe的博客-优快云博客_bigdecimal的加减乘除
-
toString() 将BigDecimal对象中的值转换成字符串
-
doubleValue() 将BigDecimal对象中的值转换成双精度数
-
floatValue() 将BigDecimal对象中的值转换成单精度数
-
longValue() 将BigDecimal对象中的值转换成长整数
-
intValue() 将BigDecimal对象中的值转换成整数
四、BigDecimal比较大小
BigDecimal a = new BigDecimal ("101");
BigDecimal b = new BigDecimal ("111");
//使用compareTo方法比较
//注意:a、b均不能为null,否则会报空指针
if(a.compareTo(b) == -1){
System.out.println("a小于b");
}
if(a.compareTo(b) == 0){
System.out.println("a等于b");
}
if(a.compareTo(b) == 1){
System.out.println("a大于b");
}
if(a.compareTo(b) > -1){
System.out.println("a大于等于b");
}
if(a.compareTo(b) < 1){
System.out.println("a小于等于b");
}