Java实现数学工具ArithUtil-BigDecimal

import java.math.BigDecimal;
import java.math.RoundingMode;

public class ArithUtil {
    private static final int DEF_DIV_SCALE = 10;

    // 小数转化为百分数, 忽略溢出
    public static double doubleToPercent(double val) {
        // 小数点后移两位
        StringBuilder s = new StringBuilder(BigDecimal.valueOf(val).toString());
        s.append("00");
        int i = s.indexOf(".");
        if (i >= 0) {
            s.deleteCharAt(i);
            s.insert(i + 2, '.');
        }
        return Double.parseDouble(s.toString());
    }

    // 百分数转化为小数, 忽略溢出
    public static double percentToDouble(double val) {
        // 小数点前移两位
        StringBuilder s = new StringBuilder(BigDecimal.valueOf(val).toString());
        s.insert(0, "00");
        int i = s.indexOf(".");
        if (i >= 0) {
            s.deleteCharAt(i);
            s.insert(i - 2, '.');
        } else {
            s.insert(s.length() - 2, '.');
        }
        return Double.parseDouble(s.toString());
    }

    // 精确的加法算法
    public static double add(double d1, double d2) {
        BigDecimal b1 = new BigDecimal(Double.toString(d1));
        BigDecimal b2 = new BigDecimal(Double.toString(d2));
        return b1.add(b2).doubleValue();

    }

    // 精确的减法算法
    public static double sub(double d1, double d2) {
        BigDecimal b1 = new BigDecimal(Double.toString(d1));
        BigDecimal b2 = new BigDecimal(Double.toString(d2));
        return b1.subtract(b2).doubleValue();
    }

    // 精确的乘法算法
    public static double mul(double d1, double d2) {
        BigDecimal b1 = new BigDecimal(Double.toString(d1));
        BigDecimal b2 = new BigDecimal(Double.toString(d2));
        return b1.multiply(b2).doubleValue();
    }

    // 相对精确的除法运算,当发生除不尽的情况时,精确到小数点以后10位
    public static double div(double d1, double d2) {
        return div(d1, d2, DEF_DIV_SCALE);
    }

    // 相对精确的除法运算,当发生除不尽的情况时,精确到小数点以后指定精度(scale),再往后的数字四舍五入
    public static double div(double d1, double d2, int scale) {
        if (scale < 0) {
            throw new IllegalArgumentException("the scale must be a positive integer or zero");
        }
        BigDecimal b1 = new BigDecimal(Double.toString(d1));
        BigDecimal b2 = new BigDecimal(Double.toString(d2));
        return b1.divide(b2, scale, RoundingMode.HALF_UP).doubleValue();
    }
}