因为double精度的原因,在我们日常编码中常常会遇到各种各样的精度问题
例如
System.out.println(0.1+0.2);
这些问题常常让人头大,之前在c语言中,我们可以通过将数字转化成字符串,然后进行高精度的运算,而在java中同样可以如此操作,而且Java还贴心的将他封装好了
我们可以通过BigDecimal类来实现
BigDecimal a=BigDecimal.valueOf(10.0);
BigDecimal b=BigDecimal.valueOf(6.0);
//加法
BigDecimal r1=a.add(b);
//减法
BigDecimal r2=a.subtract(b);
//乘法
BigDecimal r3=a.multiply(b);
//除法
BigDecimal r4=a.divide(b,2, RoundingMode.HALF_UP);
System.out.println(r1);
System.out.println(r2);
System.out.println(r3);
System.out.println(r4);
但是这里有几个注意事项
首先BigDecimal对象不能由一个double类型直接转换,会导致精度的问题,需要用valueof来避免,或用toString
但是查看vlaueof的源码就会发现,实际上二者没有什么区别,都是取转化成String类型
public static BigDecimal valueOf(double val) {
// Reminder: a zero double returns '0.0', so we cannot fastpath
// to use the constant ZERO. This might be important enough to
// justify a factory approach, a cache, or a few private
// constants, later.
return new BigDecimal(Double.toString(val));
}
其次在计算除法的时候要注意一些无法整除的情况
因为BigDecimal一定为精度运算,因而这种情况会导致程序的崩溃
因而要在除法加入保留几位小数
//保留2位小数,四舍五入
BigDecimal r4=a.divide(b,2, RoundingMode.HALF_UP);
然后要注意比较数据大小是否相同要用compareto
BigDecimal bigDecimal1 = BigDecimal.valueOf(0.01);
BigDecimal bigDecimal2 = BigDecimal.valueOf(0.01);
System.out.println(bigDecimal1.compareTo(bigDecimal2));
版权声明:本文为qq_61057438原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。