加减乘除计算工具类

一、加法

    /**
     * 加法运算
     *
     * @param a 加数
     * @return
     */
    public static double add(double... a) {
        double result = 0D;
        int len = a.length;
        if (len == 1) {
            result = a[0];
        }
        if (len >= 2) {
            BigDecimal b1 = new BigDecimal(Double.toString(a[0]));
            BigDecimal b2 = new BigDecimal(Double.toString(a[1]));
            result = b1.add(b2).doubleValue();
        }
        if (len > 2) {
            for (int i = 2; i < len; i++) {
                double v = a[i];
                BigDecimal b1 = new BigDecimal(Double.toString(result));
                BigDecimal b2 = new BigDecimal(Double.toString(v));
                result = b1.add(b2).doubleValue();
            }
        }
        return result;
    }

二、减法

    /**
     * 减法运算
     *
     * @param s 减数
     * @return
     */
    public static double sub(double... s) {
        double result = 0D;
        int len = s.length;
        if (len == 1) {
            result = s[0];
        }
        if (len >= 2) {
            BigDecimal b1 = new BigDecimal(Double.toString(s[0]));
            BigDecimal b2 = new BigDecimal(Double.toString(s[1]));
            result = b1.subtract(b2).doubleValue();
        }
        if (len > 2) {
            for (int i = 2; i < len; i++) {
                double v = s[i];
                BigDecimal b1 = new BigDecimal(Double.toString(result));
                BigDecimal b2 = new BigDecimal(Double.toString(v));
                result = b1.subtract(b2).doubleValue();
            }
        }
        return result;
    }

三、乘法

    /**
     * 乘法运算
     *
     * @param m 乘数
     * @return 保留两个小数
     */
    public static double mul(double... m) {
        double result = 0D;
        int len = m.length;
        if (len == 1) {
            result = m[0];
        }
        if (len >= 2) {
            BigDecimal b1 = new BigDecimal(Double.toString(m[0]));
            BigDecimal b2 = new BigDecimal(Double.toString(m[1]));
            if (len == 2) {//两个参数直接返回保留小数点后2位数
                result = b1.multiply(b2).setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
            } else {//大于两个参数,为减少误差,保留小数点后5位数
                result = b1.multiply(b2).setScale(5, BigDecimal.ROUND_HALF_UP).doubleValue();
            }
        }
        if (len > 2) {
            for (int i = 2; i < len; i++) {
                double v = m[i];
                BigDecimal b1 = new BigDecimal(Double.toString(result));
                BigDecimal b2 = new BigDecimal(Double.toString(v));
                if (i == len - 1) {//若为最后一个参数,则返回保留小数点后2位数
                    result = b1.multiply(b2).setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
                } else {//非最后一个参数,为减少误差,保留小数点后5位数
                    result = b1.multiply(b2).setScale(5, BigDecimal.ROUND_HALF_UP).doubleValue();
                }
            }
        }
        return result;
    }

    /**
     * 乘法运算
     *
     * @param scale 精确小数点后几位
     * @param m     乘数
     * @return 保留scale个小数
     */
    public static double mul(int scale, double... m) {
        double result = 0D;
        int len = m.length;
        if (len == 1) {
            result = m[0];
        }
        if (len >= 2) {
            BigDecimal b1 = new BigDecimal(Double.toString(m[0]));
            BigDecimal b2 = new BigDecimal(Double.toString(m[1]));
            if (len == 2) {//两个参数直接返回保留小数点后scale位数
                result = b1.multiply(b2).setScale(scale, BigDecimal.ROUND_HALF_UP).doubleValue();
            } else {//大于两个参数,为减少误差,保留小数点后scale+3位数
                result = b1.multiply(b2).setScale(scale + 3, BigDecimal.ROUND_HALF_UP).doubleValue();
            }
        }
        if (len > 2) {
            for (int i = 2; i < len; i++) {
                double v = m[i];
                BigDecimal b1 = new BigDecimal(Double.toString(result));
                BigDecimal b2 = new BigDecimal(Double.toString(v));
                if (i == len - 1) {//若为最后一个参数,则返回保留小数点后scale位数
                    result = b1.multiply(b2).setScale(scale, BigDecimal.ROUND_HALF_UP).doubleValue();
                } else {//非最后一个参数,为减少误差,保留小数点后scale+3位数
                    result = b1.multiply(b2).setScale(scale + 3, BigDecimal.ROUND_HALF_UP).doubleValue();
                }
            }
        }
        return result;
    }

四、除法

    /**
     * 除法运算
     *
     * @param d 除数
     * @return 保留两个小数
     */
    public static double div(double... d) {
        double result = 0D;
        int len = d.length;
        if (len == 1) {
            result = d[0];
        }
        if (len >= 2) {
            BigDecimal b1 = new BigDecimal(Double.toString(d[0]));
            BigDecimal b2 = new BigDecimal(Double.toString(d[1]));
            if (len == 2) {//两个参数直接返回保留小数点后2位数
                result = b1.divide(b2, 2, BigDecimal.ROUND_HALF_UP).doubleValue();
            } else {//大于两个参数,为减少误差,保留小数点后5位数
                result = b1.divide(b2, 5, BigDecimal.ROUND_HALF_UP).doubleValue();
            }
        }
        if (len > 2) {
            for (int i = 2; i < len; i++) {
                double v = d[i];
                BigDecimal b1 = new BigDecimal(Double.toString(result));
                BigDecimal b2 = new BigDecimal(Double.toString(v));
                if (i == len - 1) {//若为最后一个参数,则返回保留小数点后2位数
                    result = b1.divide(b2, 2, BigDecimal.ROUND_HALF_UP).doubleValue();
                } else {//非最后一个参数,为减少误差,保留小数点后5位数
                    result = b1.divide(b2, 5, BigDecimal.ROUND_HALF_UP).doubleValue();
                }
            }
        }
        return result;
    }

    /**
     * 除法运算
     *
     * @param scale 精确小数点后几位
     * @param d     除数
     * @return 保留scale个小数
     */
    public static double div(int scale, double... d) {
        double result = 0D;
        int len = d.length;
        if (len == 1) {
            result = d[0];
        }
        if (len >= 2) {
            BigDecimal b1 = new BigDecimal(Double.toString(d[0]));
            BigDecimal b2 = new BigDecimal(Double.toString(d[1]));
            if (len == 2) {//两个参数直接返回保留小数点后scale位数
                result = b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
            } else {//非最后一个参数,为减少误差,保留小数点后scale+3位数
                result = b1.divide(b2, scale + 3, BigDecimal.ROUND_HALF_UP).doubleValue();
            }
        }
        if (len > 2) {
            for (int i = 2; i < len; i++) {
                double v = d[i];
                BigDecimal b1 = new BigDecimal(Double.toString(result));
                BigDecimal b2 = new BigDecimal(Double.toString(v));
                if (i == len - 1) {//若为最后一个参数,则返回保留小数点后scale位数
                    result = b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
                } else {
                    result = b1.divide(b2, scale + 3, BigDecimal.ROUND_HALF_UP).doubleValue();
                }
            }
        }
        return result;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
唔,其实里面就是一个工具类加减乘除、保留两位小数。一共5个方法。。。emmmm.....为啥分这么高呢。因为宝宝想分想疯了。 附代码,有土豪就打赏打赏,没土豪的直接拿去使吧。 package cn.cisdom.base.utils; import java.math.BigDecimal; import java.text.DecimalFormat; public class Calculation { public static final DecimalFormat df = new DecimalFormat("######0.00"); /** * @methodName format2point * @desc 保留两位小数点 * @param value * @return java.lang.String * @author xm * @create 2018/6/7 12:03 **/ public static String format2point(Number value) { return df.format(value); } public static Double add(Number value1, Number value2) { BigDecimal b1 = new BigDecimal(Double.toString(value1.doubleValue())); BigDecimal b2 = new BigDecimal(Double.toString(value2.doubleValue())); return b1.add(b2).doubleValue(); } /** * 提供精确的减法运算。 * * @param value1 * 减数 * @param value2 * 被减数 * @return 两个参数的差 */ public static Double sub(Number value1, Number value2) { BigDecimal b1 = new BigDecimal(Double.toString(value1.doubleValue())); BigDecimal b2 = new BigDecimal(Double.toString(value2.doubleValue())); return b1.subtract(b2).doubleValue(); } /** * 提供精确的乘法运算。 * * @param value1 * 被乘数 * @param value2 * 乘数 * @return 两个参数的积 */ public static Double mul(Number value1, Number value2) { BigDecimal b1 = new BigDecimal(Double.toString(value1.doubleValue())); BigDecimal b2 = new BigDecimal(Double.toString(value2.doubleValue())); return b1.multiply(b2).doubleValue(); } /** * 提供精确的除法运算。 * * @param value1 * 除数 * @param value2 * 被除数 * @return 除数/被除数 */ public static Double div(Number value1, Number value2) { //MathContext mc = new MathContext(2, RoundingMode.HALF_DOWN);//精度为2,舍入模式为大于0.5进1,否则舍弃 BigDecimal b1 = new BigDecimal(Double.toString(value1.doubleValue())); BigDecimal b2 = new BigDecimal(Double.toString(value2.doubleValue())); return b1.divide(b2).doubleValue(); } public static void main(String[] args) { Double aDouble=Calculation.add(56.9, 1.67); System.out.println(aDouble); Double bDouble=Calculation.sub(99.2,aDouble); System.out.println(bDouble); } }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值