初始化,加减乘除
初始化
初始化0
//建议使用
BigDecimal bignum1 = BigDecimal.ZERO;
//或者
BigDecimal bignum1 = new BigDecimal(0);
//或者
BigDecimal bignum1 = new BigDecimal("0");
初始化int
//建议使用
BigDecimal bignum1 = new BigDecimal("10000");
//或者
BigDecimal bignum1 = new BigDecimal(10000);
初始化double
不能使用double类型来初始化BigDecimal类型,如:BigDecimal bignum1 = new BigDecimal(0.06);
要使用String类型的数值字符串来初始化,如:BigDecimal bignum1=new BigDecimal("0.06");
因为:BigDecimal(double val)这个构造方法有时是无法精确预料的
传入0.1,有可能变成0.1000000000000000055511151231257827021181583404541015625。
因为double类型无法精确地存储0.1
实例:
public class BigDecimalInitTest {
public static void main(String[] args) {
BigDecimal bignum1=new BigDecimal("0.06");
BigDecimal bignum2=new BigDecimal(0.06);
System.out.println(bignum1);
System.out.println(bignum2);
}
}
运行之后,结果为:
0.06
0.059999999999999997779553950749686919152736663818359375
加 add
BigDecimal bignum1 = new BigDecimal("10");
BigDecimal bignum2 = new BigDecimal("5");
System.out.println("和 是:" + bignum1.add(bignum2));
减 subtract
BigDecimal bignum1 = new BigDecimal("10");
BigDecimal bignum2 = new BigDecimal("5");
System.out.println("差 是:" + bignum1.subtract(bignum2));
乘 multiply
BigDecimal bignum1 = new BigDecimal("10");
BigDecimal bignum2 = new BigDecimal("5");
System.out.println("积 是:" + bignum1.multiply(bignum2));
除 divide
BigDecimal bignum1 = new BigDecimal("10");
BigDecimal bignum2 = new BigDecimal("5");
System.out.println("商 是:" + bignum1.divide(bignum2));
四舍五入后保留两位小数 setScale
BigDecimal bignum1 = new BigDecimal("10.2536");
System.out.println("四舍五入后保留两位小数 是:" + bignum1.setScale(2, BigDecimal.ROUND_HALF_UP));
除 divide,四舍五入后保留两位小数
BigDecimal bignum1 = new BigDecimal("1450.2536");
BigDecimal bignum2 = new BigDecimal(100);
System.out.println("四舍五入后保留两位小数 是:" + bignum1.divide(bignum2, 2, BigDecimal.ROUND_HALF_UP));
BigDecimal的divide方法报错
java.lang.ArithmeticException: Non-terminating decimal expansion; no exact representable decimal result.
报错语句:
a.divide(b);
原因:
JAVA中如果用BigDecimal做除法的时候一定要在divide方法中传递第二个参数,定义精确到小数点后几位,否则在不整除的情况下,结果是无限循环小数时,就会抛出以上异常。
解决方法:
a.divide(b, 2, BigDecimal.ROUND_HALF_UP);
四舍五入:BigDecimal.ROUND_HALF_UP
比较大小
compareTo
方法
compareTo方法会返回一个整数值,该值指示一个BigDecimal相对于另一个BigDecimal的顺序。如果这个BigDecimal等于另一个BigDecimal,则返回0;如果这个BigDecimal小于另一个BigDecimal,则返回-1;如果这个BigDecimal大于另一个BigDecimal,则返回1。
以下是使用compareTo方法比较两个BigDecimal对象大小的示例代码:
import java.math.BigDecimal;
public class BigDecimalComparison {
public static void main(String[] args) {
BigDecimal a = new BigDecimal("1.00");
BigDecimal b = new BigDecimal("1.0");
int comparisonResult = a.compareTo(b);
if (comparisonResult < 0) {
System.out.println("a is less than b");
} else if (comparisonResult > 0) {
System.out.println("a is greater than b");
} else {
System.out.println("a is equal to b");
}
}
}
忽略精度进行比较
如果你想忽略精度的不同,你可能需要先通过stripTrailingZeros方法移除末尾多余的零,然后再进行比较。
BigDecimal a = new BigDecimal("1.00").stripTrailingZeros();
BigDecimal b = new BigDecimal("1.0").stripTrailingZeros();
import java.math.BigDecimal;
public class BigDecimalComparison {
public static void main(String[] args) {
BigDecimal a = new BigDecimal("1.00").stripTrailingZeros();
BigDecimal b = new BigDecimal("1.0").stripTrailingZeros();
int comparisonResult = a.compareTo(b);
if (comparisonResult < 0) {
System.out.println("a is less than b");
} else if (comparisonResult > 0) {
System.out.println("a is greater than b");
} else {
System.out.println("a is equal to b");
}
}
}