其他分享
首页 > 其他分享> > List.sort报错:Comparison method violates its general contract (添加启动参数解决:useLegacyMergeSort=true)

List.sort报错:Comparison method violates its general contract (添加启动参数解决:useLegacyMergeSort=true)

作者:互联网

Comparison method violates its general contract

检查使用的sdk,使用jdk8版本以上

记录一下此次问题,最终的解决办法是 服务器端加启动参数

-Djava.util.Arrays.useLegacyMergeSort=true

作用
使用comparator排序可能在1.6版本中正常运行,而在1.7版本有时会报异常,使用这个参数 可以在运行时支持不同的排序方法

— 以下仅供参考-----
— 以下仅供参考-----
— 以下仅供参考-----
老版本的list排序 使用的是mergeSort 这个方法,在此方法中 似乎是有这样一个问题eg:ab,和ba 这两个的结果可能是不一致的,这个还未深入。参考源码图片
在这里插入图片描述

新版本的排序 使用的是TimSort 中的排序。对mergeSort的方法进行了优化,加上了各种条件下的优化判断,使用了插入排序后再用了一个交换排序来进行最终的list比较排序。
新版本的比较代码
在这里插入图片描述
可以参考一下注释说明
在这里插入图片描述
产生的报错位置代码
实际抛出的是 IllegalArgumentException
在这里插入图片描述

标签:sort,Comparison,-----,版本,使用,报错,排序,仅供参考
来源: https://blog.csdn.net/Poison54184/article/details/121020165