这是使用比较器按标题,位置和顺序排序的正确方法吗?

时间:2010-09-29 16:18:54

标签: java sorting comparator

考虑这个课程。

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方法是否正确?

3 个答案:

答案 0 :(得分: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;

        }
    }

答案 1 :(得分: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;
}

答案 2 :(得分: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;
}