编程回忆之java回忆(double和Double)

            在项目当中,我们经常会遇到数据计算,浮点数的计算算是比较经常使用到的,什么是浮点数,说白了就是小数啦。小数我们经常是用double进行声明的,但是我们写代码时候,有时候也用Double进行声明的,那他们有什么区别呢。

 

    最简单的就是double是原始类型,Double是引用类型,那他们在实际的使用当中有什么区别么。肯定是有的,最明显就是初始值问题,引用类型的初始值是null,原始类型的初始值跟他们的类型有关。还有什么不同呢,其实在工作中影响比较大的是数据大小的比较和数据的运算。原始类型可以直接使用<,>,==号进行数据大小的比较,运算可以直接使用-,+,*,/进行数据的运算,但是引用类型不能这么做。特别当数据精度提高后,直接使用Double进行加减乘除是会发生错误的。

 

    但是在项目当中,我们又很容易遇到Double对象的加减乘除,那要怎么去处理呢,下面贴出一段代码,让大家参考一下Double的加减乘数。

 

import java.math.BigDecimal;

public class douleMath {
	// 默认除法运算精度
	private static final int DEFAULT_DIV_SCALE = 10;

	/**
	 * 
	 * 提供精确的加法运算。
	 * 
	 * @param Dou1
	 * 
	 * @param Dou2
	 * 
	 * @return 两个参数的和
	 * 
	 */

	public static double add(double Dou1, double Dou2)

	{
		BigDecimal Big1 = new BigDecimal(Double.toString(Dou1));
		BigDecimal Big2 = new BigDecimal(Double.toString(Dou2));
		return Big1.add(Big2).doubleValue();

	}

	/**
	 * 
	 * 提供精确的减法运算。
	 * 
	 * @param Dou1
	 * 
	 * @param Dou2
	 * 
	 * @return 两个参数的差
	 * 
	 */

	public static double subtract(double Dou1, double Dou2)

	{
		BigDecimal Big1 = new BigDecimal(Double.toString(Dou1));
		BigDecimal Big2 = new BigDecimal(Double.toString(Dou2));
		return Big1.subtract(Big2).doubleValue();

	}

	/**
	 * 
	 * 提供精确的乘法运算。
	 * 
	 * @param Dou1
	 * 
	 * @param Dou2
	 * 
	 * @return 两个参数的积
	 * 
	 */

	public static double multiply(double Dou1, double Dou2)

	{
		BigDecimal Big1 = new BigDecimal(Double.toString(Dou1));
		BigDecimal Big2 = new BigDecimal(Double.toString(Dou2));
		return Big1.multiply(Big2).doubleValue();
	}

	/**
	 * 
	 * 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到
	 * 
	 * 小数点以后10位,以后的数字四舍五入,舍入模式采用ROUND_HALF_EVEN
	 * 
	 * @param Dou1
	 * 
	 * @param Dou2
	 * 
	 * @return 两个参数的商
	 * 
	 */

	public static double divide(double Dou1, double Dou2)

	{
		return divide(Dou1, Dou2, DEFAULT_DIV_SCALE);
	}

	/**
	 * 
	 * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
	 * 
	 * 定精度,以后的数字四舍五入。舍入模式采用ROUND_HALF_EVEN
	 * 
	 * @param Dou1
	 * 
	 * @param Dou2
	 * 
	 * @param scale
	 *            表示需要精确到小数点以后几位。
	 * 
	 * @return 两个参数的商
	 * 
	 */

	public static double divide(double Dou1, double Dou2, int scale)
	{

		return divide(Dou1, Dou2, scale, BigDecimal.ROUND_HALF_UP);
	}

	/**
	 * 
	 * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
	 * 
	 * 定精度,以后的数字四舍五入。舍入模式采用用户指定舍入模式
	 * 
	 * @param Dou1
	 * 
	 * @param Dou2
	 * 
	 * @param scale
	 *            表示需要精确到小数点以后几位
	 * 
	 * @param round_mode
	 *            表示用户指定的舍入模式
	 * 
	 * @return 两个参数的商
	 * 
	 */

	public static double divide(double Dou1, double Dou2, int scale, int round_mode) {
		if (scale < 0){
			throw new IllegalArgumentException(
					"精度必须大于等于0");
		}
		BigDecimal Big1 = new BigDecimal(Double.toString(Dou1));
		BigDecimal Big2 = new BigDecimal(Double.toString(Dou2));
		return Big1.divide(Big2, scale, round_mode).doubleValue();
	}

}


 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值