BigDecimal的常用方法
对于不需要任何准确计算精度的数字可以直接使用float或double,但是如果需要精确计算的结果,则必须使用BigDecimal类,而且使用BigDecimal类也可以进行大数的操作,下面这篇文章给大家介绍了Java中BigDecimal的加减乘除以及小数位数四舍五入取近似值、比较大小与使用注意事项,需要的朋友可以参考下
加减乘除以及小数位数四舍五入取近似值
import java.math.BigDecimal;
import java.math.RoundingMode;
import static java.math.BigDecimal.*;
public class BigDecimal{
public static void main(String[] args) {
BigDecimal b1 =new BigDecimal("0.1");
BigDecimal b2 = new BigDecimal("0.2");
BigDecimal b3 = new BigDecimal("0.825");
System.out.println(b1.add(b2));//加法0.3
System.out.println(b1.subtract(b2));//减法-0.1
System.out.println(b1.multiply(b2));//乘法0.02
System.out.println(b1.divide(b2, RoundingMode.HALF_UP));//除法0.5
System.out.println(b3.setScale(2, BigDecimal.ROUND_HALF_UP));//四舍五入取两位小数0.83
System.out.println(b3.setScale(2, BigDecimal.ROUND_HALF_DOWN));//四舍五入,0.825变成0.82,如果是5要下舍
System.out.println(b3.setScale(2, ROUND_UP));//进位处理,0.825变成0.83
System.out.println(b3.setScale(2, ROUND_DOWN));//直接删除多余的小数位,0.825变成0.82
boolean flag = b3.compareTo(ZERO) == 1 && b3.compareTo(ONE) == -1;
if (flag){
System.out.println("b3大于0小于1");
}
}
}
BigDecimal使用注意事项:
直接使用divide除法,有时会报除不尽异常
在需要精确的小数计算时再使用BigDecimal,BigDecimal的性能比double和float差,在处理庞大,复杂的运算时尤为明显。故一般精度的计算没必要使用BigDecimal。
尽量使用参数类型为String的构造函数。
BigDecimal都是不可变的(immutable)的, 在进行每一次四则运算时,都会产生一个新的对象 ,所以在做加减乘除运算时要记得要保存操作后的值。