Я знаю, что это было проблемой какое-то время, и проверил все предыдущие ответы, которые я мог получить, но все же этот не работает.
Объект "экипаж" представляет членов экипажа со званиями и другими предметами. Сравнение должно проводиться путем сравнения "assign_rank", значения int, и если это значение равно в обоих случаях, тогда "is_trainer", логическое значение, должно иметь значение.
Этот метод работал отлично, пока он работал с java < 7. Но с Java 7 я продолжаю получать следующее:
java.lang.IllegalArgumentException: Comparison method violates its general contract!
at java.util.ComparableTimSort.mergeLo(ComparableTimSort.java:714)
at java.util.ComparableTimSort.mergeAt(ComparableTimSort.java:451)
at java.util.ComparableTimSort.mergeCollapse(ComparableTimSort.java:376)
at java.util.ComparableTimSort.sort(ComparableTimSort.java:182)
at java.util.ComparableTimSort.sort(ComparableTimSort.java:146)
at java.util.Arrays.sort(Arrays.java:472)
at java.util.Collections.sort(Collections.java:155)
at dormas_flightlog.Query.getCrew(Query.java:714)
Вот источник, где некоторые потенциально опасные части уже давно не комментируются, но он все равно не работает:
public class crew implements Serializable, Comparable<crew> {
private static final long serialVersionUID = 36L;
private int flightID = 0;
private int assigned_rank = 25;
private boolean is_trainer = false;
...
@Override
public int compareTo(crew him) {
    int myRank = this.getAssigned_rank();
    int hisRank = him.assigned_rank;
    if (this == him) {
        return 0;
    }
    if (myRank > hisRank) {
        return 1;
    }
    if (myRank < hisRank) {
        return -1;
    }
    if (myRank == hisRank) {
//            if (is_trainer && !o.is_trainer) {
//                i = 1;
//            }
//            if (!is_trainer && o.is_trainer) {
//                i = -1;
//            }
//            if (is_trainer && o.is_trainer) {
//                i = 0;
//            }
//            if (!is_trainer && !o.is_trainer) {
//                i = 0;
//            }
        return 0;
    }
    return 0;
}
@Override
public int hashCode() {
    int hash = 7;
    hash = 31 * hash + this.assigned_rank;
    hash = 31 * hash + (this.is_trainer ? 1 : 0);
    return hash;
}
@Override
public boolean equals(Object o) {
    if (this == o) {
        return true;
    }
    int myRank = this.getAssigned_rank();
    int hisRank = 0;
    if (o instanceof crew) {
        crew him = (crew) o;
        hisRank = him.assigned_rank;
    } else {
        return false;
    }
    if (myRank > hisRank) {
        return false;
    }
    if (myRank < hisRank) {
        return false;
    }
    if (myRank == hisRank) {
//            if (is_trainer && !o.is_trainer) {
//                i = 1;
//            }
//            if (!is_trainer && o.is_trainer) {
//                i = -1;
//            }
//            if (is_trainer && o.is_trainer) {
//                i = 0;
//            }
//            if (!is_trainer && !o.is_trainer) {
//                i = 0;
//            }
        return true;
    }
    return false;
}
}
Реализация equals() - это просто попытка решить эту проблему. Данное исключение поставляется с или без равенства(). Я не вижу, как метод compareTo нарушает его контракт. Любая помощь очень ценится.... в один прекрасный день этот код должен работать с java 7, и я не знаю, как... Благодаря
