Re: [问题] Collections.sort更简洁的写法?

楼主: pttworld (批踢踢世界)   2015-05-29 00:30:30
有程式码带一些疑问。
MyData d1 = new MyData();
MyData d2 = new MyData();
List<MyData> dataList = new ArrayList<MyData>();
做sorting,
应排序在dataList内d1和d2的相对位置,谁前谁后。
所以当MyData里面有7个int当可能的排序判断条件,
又Override Comparator里的int compare(T o1, T o2),
: @Override
: public int compare(MyData lhs, MyData rhs) {
: return (lhs.i > rhs.i);
: }
成立的(除了型态检查错误以外,后讲)
但对于7次很奇怪,
问题在于
d1.i = 1;
d2.i = 2;
d1.j = 2;
d2.j = 1;
的时候会有问题。
所以
观念上应为
将MyData之间做比较
class MyData
{
public int i, j, k, l, m, n, o; // 七组资料
public int compareTo(MyData rhs) {
return (this.i - rhs.i) >= 0 ? 1 : 0;
// boolean理应无法转int, 故三元运算式是一种改法
}
};
然后
Collections.sort(dataList, new Comparator<MyData>() {
public int compare(MyData o1, MyData o2) {
return o1.compareTo(o2);
}
});
对于那个7次问题但条件冲突仍要解决,
也可能我功力不够无法理解7次如何处理,
可能条件之间具有优先性。
但相信应该是在class MyData的
public int compareTo(MyData rhs) {
return (this.i - rhs.i) >= 0 ? 1 : 0;
// boolean理应无法转int, 故三元运算式是一改法
}
写得更多条件的处理。

Links booklink

Contact Us: admin [ a t ] ucptt.com