我是靠谱客的博主 无心海燕,最近开发中收集的这篇文章主要介绍数字精确计算工具类 -自用,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

import java.math.BigDecimal;  
     
 
   public class Arith {  
         
       // 默认除法运算精度  
       private static final int DEF_DIV_SCALE = 10;  
     
       // 这个类不能实例化  
       private Arith() {  
             
       }  
     
       /**
        * 提供精确的加法运算     
        * @param v1           被加数
        * @param v2            加数
        * @return 两个参数的和
        */  
       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 两个参数的差
        */  
       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 两个参数的积
        */  
       public static double mul(double v1, double v2) {  
           BigDecimal b1 = new BigDecimal(Double.toString(v1));  
           BigDecimal b2 = new BigDecimal(Double.toString(v2));  
           return b1.multiply(b2).doubleValue();  
       }  
     
       /**
        * 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到 小数点以后10位,以后的数字四舍五入   
        * @param v1            被除数
        * @param v2            除数
        * @return 两个参数的商
        */  
       public static double div(double v1, double v2) {  
           return div(v1, v2, DEF_DIV_SCALE);  
       }  
     
       /**
        * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指 定精度,以后的数字四舍五入。     
        * @param v1            被除数
        * @param v2            除数
        * @param scale         表示表示需要精确到小数点以后几位。
        * @return 两个参数的商
        */  
       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();  
       }  
   }

 

最后

以上就是无心海燕为你收集整理的数字精确计算工具类 -自用的全部内容,希望文章能够帮你解决数字精确计算工具类 -自用所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(45)

评论列表共有 0 条评论

立即
投稿
返回
顶部