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