1 public classArithHelper {2
3 //默认除法运算精度
4 private static final int DEF_DIV_SCALE = 16;5
6 //这个类不能实例化
7 privateArithHelper() {8 }9
10 /**
11 * 提供精确的加法运算。12 *13 *@paramv1 被加数14 *@paramv2 加数15 *@return两个参数的和16 */
17
18 public static double add(double v1, doublev2) {19 java.math.BigDecimal b1 = newjava.math.BigDecimal(Double.toString(v1));20 java.math.BigDecimal b2 = newjava.math.BigDecimal(Double.toString(v2));21 returnb1.add(b2).doubleValue();22 }23
24 public static doubleadd(String v1, String v2) {25 java.math.BigDecimal b1 = newjava.math.BigDecimal(v1);26 java.math.BigDecimal b2 = newjava.math.BigDecimal(v2);27 returnb1.add(b2).doubleValue();28 }29
30 /**
31 * 提供精确的减法运算。32 *33 *@paramv1 被减数34 *@paramv2 减数35 *@return两个参数的差36 */
37
38 public static double sub(double v1, doublev2) {39 java.math.BigDecimal b1 = newjava.math.BigDecimal(Double.toString(v1));40 java.math.BigDecimal b2 = newjava.math.BigDecimal(Double.toString(v2));41 returnb1.subtract(b2).doubleValue();42 }43
44 public static doublesub(String v1, String v2) {45 java.math.BigDecimal b1 = newjava.math.BigDecimal(v1);46 java.math.BigDecimal b2 = newjava.math.BigDecimal(v2);47 returnb1.subtract(b2).doubleValue();48 }49
50 /**
51 * 提供精确的乘法运算。52 *53 *@paramv154 * 被乘数55 *@paramv256 * 乘数57 *@return两个参数的积58 */
59
60 public static double mul(double v1, doublev2) {61 java.math.BigDecimal b1 = newjava.math.BigDecimal(Double.toString(v1));62 java.math.BigDecimal b2 = newjava.math.BigDecimal(Double.toString(v2));63 returnb1.multiply(b2).doubleValue();64 }65
66 public static doublemul(String v1, String v2) {67 java.math.BigDecimal b1 = newjava.math.BigDecimal(v1);68 java.math.BigDecimal b2 = newjava.math.BigDecimal(v2);69 returnb1.multiply(b2).doubleValue();70 }71
72 /**
73 * 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到 小数点以后10位,以后的数字四舍五入。74 *75 *@paramv176 * 被除数77 *@paramv278 * 除数79 *@return两个参数的商80 */
81
82 public static double div(double v1, doublev2) {83 returndiv(v1, v2, DEF_DIV_SCALE);84 }85
86 public static doublediv(String v1, String v2) {87 java.math.BigDecimal b1 = newjava.math.BigDecimal(v1);88 java.math.BigDecimal b2 = newjava.math.BigDecimal(v2);89 returnb1.divide(b2, DEF_DIV_SCALE, java.math.BigDecimal.ROUND_HALF_UP).doubleValue();90 }91
92 /**
93 * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指 定精度,以后的数字四舍五入。94 *95 *@paramv1 被除数96 *@paramv2 除数97 *@paramscale 表示表示需要精确到小数点以后几位。98 *@return两个参数的商99 */
100
101 public static double div(double v1, double v2, intscale) {102 if (scale < 0) {103 throw new IllegalArgumentException("The scale must be a positive integer or zero");104 }105 java.math.BigDecimal b1 = newjava.math.BigDecimal(Double.toString(v1));106 java.math.BigDecimal b2 = newjava.math.BigDecimal(Double.toString(v2));107 returnb1.divide(b2, scale, java.math.BigDecimal.ROUND_HALF_UP).doubleValue();108 }109
110 /**
111 * 提供精确的小数位四舍五入处理。112 *113 *@paramv 需要四舍五入的数字114 *@paramscale 小数点后保留几位115 *@return四舍五入后的结果116 */
117
118 public static double round(double v, intscale) {119 if (scale < 0) {120 throw new IllegalArgumentException("The scale must be a positive integer or zero");121 }122 java.math.BigDecimal b = newjava.math.BigDecimal(Double.toString(v));123 java.math.BigDecimal one = new java.math.BigDecimal("1");124 returnb.divide(one, scale, java.math.BigDecimal.ROUND_HALF_UP).doubleValue();125 }126
127 public static double round(String v, intscale) {128 if (scale < 0) {129 throw new IllegalArgumentException("The scale must be a positive integer or zero");130 }131 java.math.BigDecimal b = newjava.math.BigDecimal(v);132 java.math.BigDecimal one = new java.math.BigDecimal("1");133 returnb.divide(one, scale, java.math.BigDecimal.ROUND_HALF_UP).doubleValue();134 }135 }