最近在计算金额时发现失精度情况,两个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]) ;
}
}
希望对你有帮助,祝你有一个好心情,加油!
若有错误、不全、可优化的点,欢迎纠正与补充!