我知道它已经被要求并回答了数百万次,但是我仍然无法弄清为什么我在分类过程中收到违规信息。这是我的代码:

Collections.sort(sorted, new Comparator<MyObject>() {
    @Override
    public int compare(MyObject m1, MyObject m2) {
        // Actual energy comparison :-
        // THE higher the energy, the earlier in the list
        float delta = m1.getTotalEnergy() - m2.getTotalEnergy();

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


我收到这个错误

java.lang.IllegalArgumentException: Comparison method violates its general contract!
        at java.util.TimSort.mergeHi(TimSort.java:895)
        at java.util.TimSort.mergeAt(TimSort.java:512)
        at java.util.TimSort.mergeForceCollapse(TimSort.java:453)
        at java.util.TimSort.sort(TimSort.java:250)
        at java.util.Arrays.sort(Arrays.java:1512)
        at java.util.ArrayList.sort(ArrayList.java:1454)
        at java.util.Collections.sort(Collections.java:175)


有任何想法吗 ?

最佳答案

假设getTotalEnergy()返回float,则可以使用

return new Float(m1.getTotalEnergy()).compareTo(m2.getTotalEnergy());


使用Float.valueOf(float)可能会更有效,并且希望它更容易阅读。

Float f1 = Float.valueOf(m1.getTotalEnergy());
Float f2 = Float.valueOf(m2.getTotalEnergy());
return f1.compareTo(f2);

关于java - Java Collections排序:比较方法违反其一般约定,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/28004269/

10-12 12:54
查看更多