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(); } }