考虑这个课程。
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方法是否正确?
答案 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;
}