package com.chincloud.bigdecimal;
import java.math.BigDecimal ;
public class Arith {
//默认除法运算精度
private static 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() ;
}
/**
* 提供精确的除法计算
* @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 v1 需要四舍五入的数字
* @param scale 小数点后保留几位
* @return 四舍五入后的结果
*/
public static double round(double v1,int scale){
if(scale<0){
throw new IllegalArgumentException("The scale must be a positive integer or zero") ;
}
BigDecimal b = new BigDecimal(Double.toString(v1)) ;
BigDecimal one = new BigDecimal("1") ;
return b.divide(one,scale,BigDecimal.ROUND_HALF_UP).doubleValue() ;
}
public static void main(String[] args) {
System.out.println(4.015*100);
System.out.println(mul(4.015, 100)) ;
System.out.println(123.3/100);
System.out.println(div(123.3,100));
System.out.println(0.05+0.01);
System.out.println(add(0.05,0.01));
System.out.println(1.0-0.42);
System.out.println(sub(1.0,0.42));
}
}
输入结果:
401.49999999999994
401.5
1.2329999999999999
1.233
0.060000000000000005
0.06
0.5800000000000001
0.58
转载自jeelee