0

このクラスを検討してください。

public class DynamicField implements Comparable<DynamicField> {
    String title;
    int position;
    int order;

    @Override
    public int compareTo(DynamicField o) {
        if(position < o.position) 
            return -1;
        if(position > o.position)
            return 1;

        if(order < o.order)
            return -1;
        if(order > o.order)
            return 1;

        return title.compareTo(o.title);

    }
}

タイトル、位置、順序で並べ替えたい場合、compareTo メソッドは正しいですか?

4

3 に答える 3

1

いいえ、このコードを試してください 更新されました

  public class DynamicField implements Comparable<DynamicField> {
        String title;
        int position;
        int order;

        @Override
        public int compareTo(DynamicField o) {
            int result = title.compareTo(o.title);
            if(result != 0) {}             
            else if(position != o.position)
                result = position-o.position;
            else if(order != o.order)
                result = order- o.order;

            return result;

        }
    }
于 2010-09-29T16:23:50.603 に答える
1

いいえ、間違った順序で比較しています。比較の順序を並べ替えると、次のように機能します。

@Override
public int compareTo(DynamicField o) {
    int c = title.compareTo(o.title);
    if (c != 0)
      return c;
    if(position < o.position) 
        return -1;
    if(position > o.position)
        return 1;
    if(order < o.order)
        return -1;
    if(order > o.order)
        return 1;
    return 0;
}
于 2010-09-29T16:37:03.643 に答える
0

これは実際には @org.life.java の回答と同じです。ただし、これはより口当たりが良いかもしれません。

@Override
public int compareTo() {
    int result = title.compareTo(o.title);
    if (result == 0)
        result = position - o.position;
    if (result == 0)
        result = order - o.order;
    return result;
}
于 2010-09-29T20:12:19.033 に答える