BigDecimal类
BigDecimal类
很多实际应用中需要精确运算,而double是近似值存储,不再符合要求,需要借助BigDecimal。
public static void main(String[] args) {
double num1=1.0;
double num2=0.9;
System.out.println(num1-num2); //输出0.09999999999999998
//原因是double类型在内存中近似存储
//使用BigDecimal进行精确运算
BigDecimal n1 = new BigDecimal("1.0"); //注意要用字符串,否则结果仍然有误差
BigDecimal n2 = new BigDecimal("0.9");
BigDecimal n3=n1.subtract(n2); //进行减法运算
System.out.println(n3);
//注意:除法如果除不尽会报错,要使用除法的一个重载方法保留小数
BigDecimal b1 = new BigDecimal("10");
BigDecimal b2 = new BigDecimal("3");
BigDecimal b3=b1.divide(b2,2,BigDecimal.ROUND_HALF_UP); //BigDecimal.ROUND_HALF_UP为四舍五入
System.out.println(b3);
}
注意除法:
除法: divide (BigDecimal bd,int scal, RoundingMade mode)
参数scal :指定精确到小数点后几位。
参数mode :
指定小数部分的取舍模式,通常采用四舍五入的模式,
取值为BigDecimal.ROUND_HALF_UP。
本文来自博客园,作者:望穿先生,转载请注明原文链接:https://www.cnblogs.com/wangchuanxiansheng/p/15839478.html