初始化:
BigDecimal num = new BigDecimal(value); value可以直接写数字也可以是String字符串
BigDecimal num1 = new BigDecimal(0.005);
BigDecimal num2 = new BigDecimal(10);
BigDecimal num3 = new BigDecimal(-10);
BigDecimal num4 = new BigDecimal("0.005");
BigDecimal num5 = new BigDecimal("10");
BigDecimal num6 = new BigDecimal("-10");
加法:
add() 函数
BigDecimal add = num1.add(num2);
减法:
subtract() 函数
BigDecimal subtract = num1.subtract(num2);
乘法:
multiply() 函数
BigDecimal multiply = num1.multiply(num2);
除法:
divide() 函数
BigDecimal divide1 = num1.divide(num4);
BigDecimal divide2 = num1.divide(num4,2,BigDecimal.ROUND_HALF_UP);
绝对值:
abs() 函数
BigDecimal multiply = num1.multiply(num4).abs();
BigDecimal divide1 = num1.divide(num4).abs();
BigDecimal divide3 = num1.divide(num4,2,BigDecimal.ROUND_HALF_UP).abs();
小数点操作:
BigDecimal.setScale()方法用于格式化小数点
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)向最接近的数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。
例子:
BigDecimal divide = num1.divide(num3);
BigDecimal bigDecimal = divide.setScale(2, BigDecimal.ROUND_HALF_UP);
// 保留小数,小数位不足补0
// 0.00 表示保留两位小数,#.00 表示保留两位小数,#.0000 表示保留4位小数,0.00#表示保留3位小数,最后一位小数均为四舍五入结果
DecimalFormat decimalFormat = new DecimalFormat("0.00#");
String strVal = decimalFormat.format(value);
例子:
DecimalFormat decimalFormat = new DecimalFormat("0.00#");
String format = decimalFormat.format(bigDecimal);