Java_util_Double类型运算

本文介绍了一个用于处理浮点数运算的Java类,包括加法、减法、乘法、除法及四舍五入等功能,并确保了运算的准确性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public class Arithmetic4Double {    

        //默认除法运算精度    

        private static final int DEF_DIV_SCALE = 10;    

           

        //所有方法均用静态方法实现,不允许实例化    

        private Arithmetic4Double() {}    

        

        /**  

         * 实现浮点数的加法运算功能  

         * @param v1 加数1  

         * @param v2 加数2  

         * @return v1+v2的和  

         */    

        public static double add(double v1,double v2) {    

            BigDecimal b1 = new BigDecimal(Double.toString(v1));    

            BigDecimal b2 = new BigDecimal(Double.toString(v2));    

            return b1.add(b2).doubleValue();    

        }    

        /**  

         * 实现浮点数的减法运算功能  

         * @param v1 被减数  

         * @param v2 减数  

         * @return v1-v2的差  

         */    

        public static double sub(double v1,double v2) {    

            BigDecimal b1 = new BigDecimal(Double.toString(v1));    

            BigDecimal b2 = new BigDecimal(Double.toString(v2));    

            return b1.subtract(b2).doubleValue();    

        }    

        /**  

         * 实现浮点数的乘法运算功能  

         * @param v1 被乘数  

         * @param v2 乘数  

         * @return v1×v2的积  

         */    

        public static double multi(double v1,double v2) {    

            BigDecimal b1 = new BigDecimal(Double.toString(v1));    

            BigDecimal b2 = new BigDecimal(Double.toString(v2));    

            return b1.multiply(b2).doubleValue();    

        }    

        

        /**  

         * 实现浮点数的除法运算功能  

         * 当发生除不尽的情况时,精确到小数点以后DEF_DIV_SCALE位(默认为10位),后面的位数进行四舍五入。  

         * @param v1 被除数  

         * @param v2 除数  

         * @return v1/v2的商  

         */    

        public static double div(double v1,double v2) {    

         BigDecimal b1 = new BigDecimal(Double.toString(v1));    

            BigDecimal b2 = new BigDecimal(Double.toString(v2));    

            return b1.divide(b2,DEF_DIV_SCALE,BigDecimal.ROUND_HALF_UP).doubleValue();    

        }    

        

        /**  

         * 实现浮点数的除法运算功能  

         * 当发生除不尽的情况时,精确到小数点以后scale位,后面的位数进行四舍五入。  

         * @param v1 被除数  

         * @param v2 除数  

         * @param scale 表示需要精确到小数点以后几位  

         * @return v1/v2的商  

         */    

        public static double div(double v1,double v2,int scale) {    

            if (scale < 0) {    

                throw new IllegalArgumentException(    

                    "The scale must be a positive integer or zero");    

            }    

            BigDecimal b1 = new BigDecimal(Double.toString(v1));    

            BigDecimal b2 = new BigDecimal(Double.toString(v2));    

            return b1.divide(b2,scale,BigDecimal.ROUND_HALF_UP).doubleValue();    

        }    

        

        /**  

         * 提供精确的小数位四舍五入功能  

         * @param v 需要四舍五入的数字  

         * @param scale 小数点后保留几位  

         * @return 四舍五入后的结果  

         */    

        public static double round(double v,int scale) {    

            if (scale < 0) {    

                throw new IllegalArgumentException(    

                    "The scale must be a positive integer or zero");    

            }    

            BigDecimal b = new BigDecimal(Double.toString(v));    

            BigDecimal one = new BigDecimal("1");    

            return b.divide(one,scale,BigDecimal.ROUND_HALF_UP).doubleValue();    

        }    

    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值