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比较建议用compareTo_第1张图片
运行结果不出所料,BigDecimal的equals方法当精度不一样的时候也当做不相等,而compareTo方法却可以忽略精度的不同,只比较数值是否相同。

看看源码

BigDecimal的equals方法

BigDecimal比较建议用compareTo_第2张图片
源码里说的很详细,equals方法比较value和scale(数值和精度),精度不一样,也返回false。

BigDecimal的compareTo方法

BigDecimal比较建议用compareTo_第3张图片
compareTo也说得很详细,数值相同但是精度不同的两个数(例如2.0和2.00)被认为是相等的两个数,返回0。
另外对于a.compareTo(b)方法

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

(想自学习编程的小伙伴请搜索圈T社区,更多行业相关资讯更有行业相关免费视频教程。完全免费哦!)

你可能感兴趣的:(圈T社区)