前言
前两天测试发现一个Bug,告诉我说他明明只修改了订单详情中商品的数量,为什么提示说订单中商品单价不能修改(后台限制了特殊单子的单价不能修改),但是他明明没有修改商品的单价,这就很奇怪了。我看了下入参,修改接口传的该商品的单价为price=222,数据库中该商品的单价为222.000000。该字段为BigDecimal类型,除了精度不一样,值是相等的,而后台校验相等用的是equals。而网上查资料BigDecimal用的比较多的是compareTo方法。
测试两种比较
复制代码
1
2
3
4
5
6
7
8
9
10public 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
(想自学习编程的小伙伴请搜索圈T社区,更多行业相关资讯更有行业相关免费视频教程。完全免费哦!)
最后
以上就是辛勤睫毛最近收集整理的关于BigDecimal比较建议用compareTo的全部内容,更多相关BigDecimal比较建议用compareTo内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复