目录
为什么要用BigDecimal ?
商业计算中,货币类或者小数点运算涉及到精度问题,BigDecimal解决高精度问题,保证数值正确。 对比float/double更偏向工程及科学运算,二进制浮点运算,在更广的数值上得到近似计算规律,但是涉及到钱等则需要准确的结果,故使用BigDecimal。
构造BigDecimal
BigDecimal(int)、BigDecimal(double)、BigDecimal(long)、BigDecimal(String)
创建一个整型/双精度/长整型/字符串数字初始值
一般使用BigDecimal(String)来初始化值,因为BigDecimal(double)无法控制精度
BigDecimal a = new BigDecimal("0.01");
加减乘除
均创建新的对象而非在原来基础上改变数值
加法add
BigDecimal a = new BigDecimal("0.01");
BigDecimal b = new BigDecimal("0.02");
BigDecimal result = a.add(b);
减法subtract
BigDecimal a = new BigDecimal("0.01");
BigDecimal b = new BigDecimal("0.02");
BigDecimal result = a.subtract(b); //结果为-0.01
乘法multiply
BigDecimal a = new BigDecimal("0.01");
BigDecimal b = new BigDecimal("0.02");
BigDecimal result = a.multiply(b);
除法divide
BigDecimal a = new BigDecimal("0.01");
BigDecimal b = new BigDecimal("0.02");
BigDecimal result = a.divide(b);
当分母为0,报错 java.lang.ArithmeticException: Division by zero