Comparison method violates its general contract 出现原因和解决方法

  • 错误如下:
    在这里插入图片描述
  • 代码如下:
    在这里插入图片描述

刚开始运行,没有什么问题,当我数据量一大的时候,就开时抛出异常,然后一点点拆解,我发现
当nums1和nums2如下时,即list存在太多相同的数组就会抛出这个异常。

		int[]nums1 = {-1,-1,0,0,1,1};
        int[] nums2 ={-1,-1,0,0,1,1};
  • 改进后的代码

在这里插入图片描述

当两个元素相等时,返回0即可。 但问题又来了,前面我有一些数据比较也是相等的,并没有报这个异常,然后就去百度,查资料。
解释如下:
在 JDK7 版本以上,Comparator 要满足自反性,传递性,对称性,不然 Arrays.sort,Collections.sort
会报 IllegalArgumentException 异常。

  • 自反性:当 两个相同的元素相比时,compare必须返回0,也就是compare(o1, o1) = 0;

  • 反对称性:如果compare(o1,o2) = 1,则compare(o2, o1)必须返回符号相反的值也就是 -1;

  • 传递性:如果 a>b, b>c, 则 a必然大于c。也就是compare(a,b)>0, compare(b,c)>0,
    则compare(a,c)>0

回到上面的例子,当ab 时,我返回的是-1,假设返回-1是a>b, 当 bc时 返回的也是 -1 即b>c,
当c==a时,返回的也是 -1 ,这个时候底层在调用TimSort中mergeHi()进行数据合并是就会出现这样的问题,从而抛出异常。
所以在使用Comparator 接口的比较方法时,一定要规范返回值。

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值