BigDecimal bignum1 = new BigDecimal("8.88");
BigDecimal bignum2 = new BigDecimal("6.66");
BigDecimal bignum3 = null;
加法
bignum3 = bignum1.add(bignum2);
System.out.println("和 是:" + bignum3);
减法
bignum3 = bignum1.subtract(bignum2);
System.out.println("差 是:" + bignum3);
乘法
bignum3 = bignum1.multiply(bignum2);
System.out.println("积 是:" + bignum3);
除法
bignum3 = bignum1.divide(bignum2);
System.out.println("商 是:" + bignum3);
BigDecimal 判空
bignum1 .compareTo(BigDecimal.ZERO)==0,可以比较是否等于0,返回true则等于0,返回false,则不等于0
其他运算方法
乘方:pow(int)
取绝对值:abs()
取反:negate()
对比:compareTo(BigDecimal)
设置小数点精确度:setScale(int)
其实divide方法有可以传三个参数
public BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)
第一参数表示除数, 第二个参数表示小数点后保留位数,
第三个参数表示舍入模式,只有在作除法运算或四舍五入时才用到舍入模式,有下面这几种
ROUND_CEILING //向正无穷方向舍入
ROUND_DOWN //向零方向舍入
ROUND_FLOOR //向负无穷方向舍入
ROUND_HALF_DOWN //向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向下舍入, 例如1.55 保留一位小数结果为1.5
ROUND_HALF_EVEN //向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,如果保留位数是奇数,使用ROUND_HALF_UP,如果是偶数,使用ROUND_HALF_DOWN
ROUND_HALF_UP //向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向上舍入, 1.55保留一位小数结果为1.6
ROUND_UNNECESSARY //计算结果是精确的,不需要舍入模式
ROUND_UP //向远离0的方向舍入
按照各自的需要,可传入合适的第三个参数。四舍五入采用 ROUND_HALF_UP
这个方法可以更加简单地实现将一个double型数值保留两位小数
double value = newBigDecimal(num).setScale(2,BigDecimal.ROUND_HALF_UP).doubleValue();
double value2 = new BigDecimal(num).divide(new BigDecimal(10)).doubleValue();
减乘除其实最终都返回的是一个新的BigDecimal对象,因为BigInteger与BigDecimal都是不可变的(immutable)的,在进行每一步运算时,都会产生一个新的对象