Java计算失精

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/cheng_feng_xiao_zhan/article/details/84660820

最近在计算金额时发现失精度情况,两个Double类型"496.015"+"1169.0"计算失精,在网上研究看了一下代码,验证如下:

可以使用BigInteger操作大整数
可以使用BigDecimal指定小数的保留位数

import java.math.BigDecimal;
import java.math.BigInteger;

public class BigDecimalUtil {
	
	public static void main(String[] args){
		double a = 496.015;
		double b = 1169.0;
		System.out.println(add(a, b));//计算失精
		
		String str1 = "496.015";
		String str2 = "1169.0";
		System.out.println(add(str1, str2));//正常
	}
	
	/**
	 * 该方法传参Double类型,
	 * 进行转化为BigDecimal时不准确
	 * @param d1
	 * @param d2
	 * @return
	 */
    public static double add(double d1,double d2){// 进行加法计算  
        BigDecimal b1 = new BigDecimal(d1) ;
        BigDecimal b2 = new BigDecimal(d2) ;
        BigDecimal add = b1.add(b2);
        return add.doubleValue() ;  
    }
    
    /**
     * 传参数金额为String类型,进行转化为BigDecimal时没有失精
     * @param str1
     * @param str2
     * @return
     */
    public static BigDecimal add(String str1,String str2){// 进行加法计算  
        BigDecimal b1 = new BigDecimal(str1) ;
        BigDecimal b2 = new BigDecimal(str2) ;
        return b1.add(b2);  
    }
    
    public static double sub(double d1,double d2){// 进行减法计算  
        BigDecimal b1 = new BigDecimal(d1) ;  
        BigDecimal b2 = new BigDecimal(d2) ;  
        return b1.subtract(b2).doubleValue() ;  
    }
    public static double mul(double d1,double d2){// 进行乘法计算  
        BigDecimal b1 = new BigDecimal(d1) ;  
        BigDecimal b2 = new BigDecimal(d2) ;  
        return b1.multiply(b2).doubleValue() ;  
    }
    public static double div(double d1,double d2,int len){// 进行除法计算  
        BigDecimal b1 = new BigDecimal(d1) ;  
        BigDecimal b2 = new BigDecimal(d2) ;  
        return b1.divide(b2,len,BigDecimal.ROUND_HALF_UP).doubleValue() ;  
    }
    public static double round(double d,int len){// 进行四舍五入  
        BigDecimal b1 = new BigDecimal(d) ;  
        BigDecimal b2 = new BigDecimal(1) ;// 技巧  
        return b1.divide(b2,len,BigDecimal.ROUND_HALF_UP).doubleValue() ;  
    }
    
    public static void bigIntegerDemo(String[] args) {  
        BigInteger bi1 = new BigInteger("1000000") ;  // 声明BigInteger对象  
        BigInteger bi2 = new BigInteger("1000000") ;  // 声明BigInteger对象  
        System.out.println("加法操作:" + bi2.add(bi1)) ;    // 加法操作  
        System.out.println("减法操作:" + bi2.subtract(bi1)) ;   // 减法操作  
        System.out.println("乘法操作:" + bi2.multiply(bi1)) ;   // 乘法操作  
        System.out.println("除法操作:" + bi2.divide(bi1)) ; // 除法操作  
        System.out.println("最大数:" + bi2.max(bi1)) ;  // 求出最大数  
        System.out.println("最小数:" + bi2.min(bi1)) ;  // 求出最小数  
        BigInteger result[] = bi2.divideAndRemainder(bi1) ; // 求出余数的除法操作  
        System.out.println("商是:" + result[0] + ";余数是:" + result[1]) ;  
    }
}

希望对你有帮助,祝你有一个好心情,加油!

若有错误、不全、可优化的点,欢迎纠正与补充!

猜你喜欢

转载自blog.csdn.net/cheng_feng_xiao_zhan/article/details/84660820
今日推荐