BigDecimal比较建议用compareTo

前言

前两天测试发现一个Bug,告诉我说他明明只修改了订单详情中商品的数量,为什么提示说订单中商品单价不能修改(后台限制了特殊单子的单价不能修改),但是他明明没有修改商品的单价,这就很奇怪了。我看了下入参,修改接口传的该商品的单价为price=222,数据库中该商品的单价为222.000000。该字段为BigDecimal类型,除了精度不一样,值是相等的,而后台校验相等用的是equals。而网上查资料BigDecimal用的比较多的是compareTo方法。

测试两种比较

public class BigDecimalDemo {

    public static void main(String [] args) {
        BigDecimal decimal1 = new BigDecimal("222");
        BigDecimal decimal2 = new BigDecimal("222.000000");
        System.out.println(decimal1.equals(decimal2));
        System.out.println(decimal1.compareTo(decimal2));
    }
}
复制代码

运行结果

运行结果不出所料,BigDecimal的equals方法当精度不一样的时候也当做不相等,而compareTo方法却可以忽略精度的不同,只比较数值是否相同。

看看源码

BigDecimal的equals方法

源码里说的很详细,equals方法比较value和scale(数值和精度),精度不一样,也返回false。

BigDecimal的compareTo方法

compareTo也说得很详细,数值相同但是精度不同的两个数(例如2.0和2.00)被认为是相等的两个数,返回0。 另外对于a.compareTo(b)方法

  • a<b, 返回-1
  • a=b,返回0
  • a>b, 返回1

猜你喜欢

转载自juejin.im/post/5d5a3882f265da03d60effb0
今日推荐