- 首先为什么会使用BigDecimal,而不使用Double或者float进行计算,因为Double和Float的计算结果会出现误差(底层为二进制进行计算),而BigDecimal底层不是使用二进制进行计算的。所以进行比较大的数之间的计算时,需要精确计算,可以使用BigDecimal。
- BigDecimal都是不可变的(immutable)的,在进行每一步运算时,都会产生一个新的对象,所以在做加减乘除运算时千万要保存操作后的值。
1. BigDecimal的加减乘除
BigDecimal b1 = new BigDecimal("1");
BigDecimal b2 = new BigDecimal("5");
//加法运算
System.out.println(b1.add(b2));
//减法运算
System.out.println(b1.subtract(b2));
//乘法运算
System.out.println(b1.multiply(b2));
//除法运算,如果除不尽程序会报错
System.out.println(b1.divide(b2));
运行结果:
6
-4
5
0.2
2. BigDecimal的比较 :
BigDecimal b1 = new BigDecimal("1");
BigDecimal b2 = new BigDecimal("5");
System.out.println(b1.compareTo(b2));//前面的数小于后面的数则输出-1
System.out.println(b2.compareTo(b1));//前面的数大于后面的数则输出1
System.out.println(b1.compareTo(b1));//等于则输出0
运行结果:
-1
1
0
3. 常用数学方法
-
abs()
返回 BigDecimal,其值为此 BigDecimal 的绝对值。 -
x.equals(Object X)
比较此 BigDecimal 与指定的 Object 的相等性。 -
bigDecimal1.max( bigDecimal2)
返回此 BigDecimal 和 val 的最大值。 -
bigDecimal1.min(BigDecimal2)
返回此 BigDecimal 和 val 的最小值。