利用BigDecimal精确的计算浮点数

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值