Collections.sort()坑!!!

本文探讨了在使用Java的Collections.sort()方法时遇到的问题。当重写比较器的compare方法时,若未处理相等条件可能导致IllegalArgumentException异常。通过完整实现比较逻辑解决了此问题。

Collections.sort()中重写compare导致突然开始报错?!?!

if  (result > 0) {
return -1;
} else {
return 1;
}

compare里用同样的上面返回,同样的环境,一处正常一处报java.lang.IllegalArgumentException: Comparison method violates its general contract!

换成

if (result > 0) {
return -1;
} else if (result == 0) {
return 0;
} else {
return 1;
}

就没问题了,少个比较相等的返回!

暂时发现可能就是这个问题,但为什么另一个正常运行还不清楚!

参考:Collections.sort()问题

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值