java.lang.IllegalArgumentException: Comparison method violates its general contract!
时间: 2023-10-16 14:03:30 浏览: 43
这个错误通常是由于比较器实现不符合比较器的约定所导致的。在Java中,比较器必须满足三个条件:
1. 自反性:对于任何x,x==x必须为true。
2. 对称性:对于任何x和y,如果x<y,则y>x必须为true。
3. 传递性:对于任何x、y和z,如果x<y且y<z,则x<z必须为true。
如果比较器实现不符合这些条件,则会出现"Comparison method violates its general contract"错误。
要解决这个问题,您可以检查比较器实现是否符合上述条件。如果不符合条件,则需要更改实现以满足这些条件。如果您使用的是某个开源库中的比较器,则可以查看该库的文档或联系该库的维护者以解决问题。
相关问题
java.lang.IllegalArgumentException: Comparison method violates its general c
java.lang.IllegalArgumentException: Comparison method violates its general contract是一个常见的异常,通常在使用Java中的排序算法时会出现。这个异常的原因是排序算法的比较器没有遵守Java中的比较器规范,导致排序算法无法正常工作。解决这个问题的方法是检查比较器的实现是否符合规范,具体规范如下:
1. 自反性:对于任意非空引用x,x.equals(x)应该返回true。
2. 对称性:对于任意非空引用x和y,如果x.equals(y)返回true,则y.equals(x)也应该返回true。
3. 传递性:对于任意非空引用x、y和z,如果x.equals(y)返回true,并且y.equals(z)也返回true,则x.equals(z)也应该返回true。
4. 一致性:对于任意非空引用x和y,多次调用x.equals(y)应该始终返回true或始终返回false,前提是对象上equals比较中所用的信息没有被修改。
5. 非空性:对于任意非空引用x,x.equals(null)应该返回false。
如果比较器的实现不符合这些规范中的任何一个,就可能会导致java.lang.IllegalArgumentException: Comparison method violates its general contract异常的出现。
Caused by: java.lang.IllegalArgumentException: Comparison method violates its general contract! at java.util.TimSort.mergeLo(TimSort.java:777) at java.util.TimSort.mergeAt(TimSort.java:514) at java.util.TimSort.mergeCollapse(TimSort.java:441) at java.util.TimSort.sort(TimSort.java:245) at java.util.Arrays.sort(Arrays.java:1512) at java.util.stream.SortedOps$SizedRefSortingSink.end(SortedOps.java:348) at java.util.stream.AbstractPipeline.copyIntoWithCancel(AbstractPipeline.java:500) at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:486) at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:472) at java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:708) at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234) at java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:499) at
这个错误通常是由于排序算法的比较方法实现不正确引起的。在 Java 中,如果实现了 Comparator 接口的 compare() 方法,必须满足如下三个条件:
1. 自反性:对于所有 x,compare(x, x) == 0。
2. 对称性:对于所有 x 和 y,如果 compare(x, y) > 0,则 compare(y, x) < 0。
3. 传递性:对于所有 x、y 和 z,如果 compare(x, y) > 0 且 compare(y, z) > 0,则 compare(x, z) > 0。
如果这些条件没有被满足,就可能会导致类似于“Comparison method violates its general contract”这样的错误。
要解决这个问题,可以检查比较方法的实现,确保它满足上述三个条件。另外,如果使用了 Java 8 的流式操作和排序方法,也可以尝试使用 sorted() 方法的重载版本:sorted(Comparator.comparing(...).thenComparing(...)),它会同时应用多个比较条件,避免出现违反比较契约的情况。