文章目录
- 前言
- 问题解决
- 问题解决
前言
在之前做的一个项目中,为了保证BigDecimal
在除数 divide
时,如果被除数为0,出现java.lang.ArithmeticException: / by zero
报错问题,写了一个对比。具体代码如下:
public static BigDecimal getScale(BigDecimal data1,BigDecimal data2,Integer scale){
if(Objects.isNull(data1) || BigDecimal.ZERO.equals(data1)
|| Objects.isNull(data2) || BigDecimal.ZERO.equals(data2)){
return BigDecimal.ZERO;
}
return data1.divide(data2,scale,BigDecimal.ROUND_HALF_UP);
}
咋一看,的确没毛病。
当被除数为
0
时,直接由判断返回,并不会进入下面的计算流程。
但,却忽略了一个问题,如果数据是从数据库中查询,数据库中设定的数的格式是0.00
时,此时完美绕开了判断。
原因就在于:
new BigDecimal("0.00").equals(BigDecimal.ZERO)
为false
。
问题解决
其实这类问题,很好解决,在BigDecimal源码中,有一个compareTo
的方法
简单写个demo,验证效果:
System.out.println(new BigDecimal("0.0").compareTo(BigDecimal.ZERO));
System.out.println(new BigDecimal("0.00").compareTo(BigDecimal.ZERO));
System.out.println(new BigDecimal("0.0000000").compareTo(BigDecimal.ZERO));
System.out.println(new BigDecimal("0").compareTo(BigDecimal.ZERO));
System.out.println(new BigDecimal("0.1").compareTo(BigDecimal.ZERO));
分别打印上面的执行结果,可以发现
不管是什么格式的0,与0相等则返回0;比0大则返回1;比0小则返回-1。
问题解决
通过compareTo
就能解决不同格式的零值,与0使用equals相比为false的问题。