初始化,加减乘除
- //建议使用
- BigDecimal bignum1 = BigDecimal.ZERO;
-
- //或者
- BigDecimal bignum1 = new BigDecimal(0);
-
- //或者
- BigDecimal bignum1 = new BigDecimal("0");
- //建议使用
- BigDecimal bignum1 = new BigDecimal("10000");
-
- //或者
- BigDecimal bignum1 = new BigDecimal(10000);
不能使用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
- BigDecimal bignum1 = new BigDecimal("10");
- BigDecimal bignum2 = new BigDecimal("5");
- System.out.println("和 是:" + bignum1.add(bignum2));
- BigDecimal bignum1 = new BigDecimal("10");
- BigDecimal bignum2 = new BigDecimal("5");
- System.out.println("差 是:" + bignum1.subtract(bignum2));
- BigDecimal bignum1 = new BigDecimal("10");
- BigDecimal bignum2 = new BigDecimal("5");
- System.out.println("积 是:" + bignum1.multiply(bignum2));
- BigDecimal bignum1 = new BigDecimal("10");
- BigDecimal bignum2 = new BigDecimal("5");
- System.out.println("商 是:" + bignum1.divide(bignum2));
- BigDecimal bignum1 = new BigDecimal("10.2536");
- System.out.println("四舍五入后保留两位小数 是:" + bignum1.setScale(2, BigDecimal.ROUND_HALF_UP));
- BigDecimal bignum1 = new BigDecimal("1450.2536");
- BigDecimal bignum2 = new BigDecimal(100);
- System.out.println("四舍五入后保留两位小数 是:" + bignum1.divide(bignum2, 2, BigDecimal.ROUND_HALF_UP));
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