BigDecimal简介
Java在java.mat
h包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数。在实际应用中,需要对更大或者更小的数进行运算和处理。float和double只能用来做科学计算或者是工程计算,在商业计算中要用java.math.BigDecimal。BigDecimal所创建的是对象,我们不能使用传统的+、-、*、/等算术运算符直接对其对象进行数学运算,而必须调用其相对应的方法。方法中的参数也必须是BigDecimal的对象。构造器是类的特殊方法,专门用来创建对象,特别是带有参数的对象。
提起BigDecimal,相信大家都使用过,之所以总结这篇呢,是因为最近发现项目中使用的不是太规范,在某些场景下甚至出现代码抛出异常的情况,
所以就总结了这篇,希望大家在使用时,可以少踩一些坑。
1. 基本运算
1.1 加法
BigDecimal number1 = new BigDecimal("88.88"); BigDecimal number2 = new BigDecimal("11.12"); BigDecimal number3 = number1.add(number2); System.out.println("number1 add number2 = " + number3);
输出结果:
number1 add number2 = 100.00
1.2 减法
BigDecimal number1 = new BigDecimal("88.88"); BigDecimal number2 = new BigDecimal("11.12"); BigDecimal number3 = number1.subtract(number2); System.out.println("number1 subtract number2 = " + number3);
输出结果:
number1 subtract number2 = 77.76
1.3 乘法
BigDecimal number1 = new BigDecimal("88.88"); BigDecimal number2 = new BigDecimal("11.12"); BigDecimal number3 = number1.multiply(number2); System.out.println("number1 multiply number2 = " + number3);
输出结果:
number1 multiply number2 = 988.3456
1.4 除法
BigDecimal number1 = new BigDecimal("88"); BigDecimal number2 = new BigDecimal("11"); BigDecimal number3 = number1.divide(number2); System.out.println("number1 divide number2 = " + number3);
输出结果:
number1 divide number2 = 8
因为上面2个数可以整除,所以这么用没有问题,不过一但不能被整除,这么用就会有潜在的风险,会抛出java.lang.ArithmeticException
异常,所以强烈建议像下面这样使用:
BigDecimal number1 = new BigDecimal("88.88"); BigDecimal number2 = new BigDecimal("11.12"); BigDecimal number3 = number1.divide(number2, 2, RoundingMode.HALF_UP); System.out.println("number1 divide number2 = " + number3);
输出结果:
number1 divide number2 = 7.99
此时使用的divide()方法源码如下所示:
public BigDecimal divide(BigDecimal divisor, int scale, RoundingMode roundingMode) { return divide(divisor, scale, roundingMode.oldMode); }
这里的scale指的是要保留的小数位数,我们传的是2,即保留2位小数。
这里的roundingMode指的是舍入模式,我们这里传的是RoundingMode.HALF_UP
,即经常使用的四舍五入模式。
1.5 保留小数位数
如果我们想对BigDecimal类型保留小数位数,可以使用setScale()方法,使用方法如下所示:
BigDecimal number1 = new BigDecimal("88.88"); BigDecimal number2 = new BigDecimal("11.12"); BigDecimal number3 = number1.multiply(number2); System.out.println("number1 multiply number2 = " + number3); // 保留3位小数,四舍五入 BigDecimal number4 = number3.setScale(3, RoundingMode.HALF_UP); System.out.println("number3 setScale = " + number4);