问题代码:
Collections.sort(resultList, (o1, o2) -> {
return o1.getClinicItemCode().equals(o2.getClinicItemCode()) ? -1 : 1;
});
原因:
JDK7中的Collections.Sort方法实现中,如果两个值是相等的,那么compare方法需要返回0,否则 可能 会在排序时抛错,而JDK6是没有这个限制的。
2023版本的IDEA,在这段代码下会有警告
在 JDK7 版本以上,Comparator 要满足自反性,传递性,对称性,不然 Arrays.sort 或者 Collections.sort 会报 IllegalArgumentException 异常。
规约:
1) 自反性:x,y 的比较结果和 y,x 的比较结果相反。
2) 传递性:x>y,y>z,则 x>z。
3) 对称性:x=y,则 x,z 比较结果和 y,z 比较结果相同。
解决方案:
1、不修改代码
在JVM的启动参数中加入如下参数,表明继续使用JDK6的排序算法:
-Djava.util.Arrays.useLegacyMergeSort=true
2、修改代码
o1.getClinicItemCode().equals(o2.getClinicItemCode()) ? -1 : 1
替换为
o1.getClinicItemCode().compareTo(o2.getClinicItemCode())
用自带的compareTo()方法去比较
参考博客: