如果有人正在寻找一个通用的实现,我已经做了一个。
基本抽象类:
public abstract class AbstractSortHelper<T> implements Comparable<AbstractSortHelper<T>> {
protected final int index;
protected final T data;
public AbstractSortHelper(int index, T data) {
this.index = index;
this.data = data;
}
public int getIndex() {
return index;
}
public T getData() {
return data;
}
}
第一个可用于实现 Comparable 的对象的扩展类:
public class ComparableSortHelper<T extends Comparable> extends AbstractSortHelper<T> {
public ComparableSortHelper(int index, T data) {
super(index, data);
}
@Override
public int compareTo(AbstractSortHelper<T> o) {
return this.data.compareTo(o.data);
}
}
可用于未实现 Comparable 的对象的第二个扩展类。使用时你必须实现一个比较器:
public abstract class ComparatorSortHelper<T> extends AbstractSortHelper<T> implements Comparator<T> {
public ComparatorSortHelper(int index, T data) {
super(index, data);
}
@Override
public int compareTo(AbstractSortHelper<T> {
return compare(this.data, o.data);
}
}
扩展 ComparatorSortHelper 如下所示:
class DataSortHelper extends ComparatorSortHelper<Object[]> {
public DataSortHelper(int index, Object[] data) {
super(index, data);
}
@Override
public int compare(Object[] o1, Object[] o2) {
return Integer.compare((Integer) o1[0], (Integer) o2[0]);
}
}
使用这个之后,排序就简单了:
List<DataSortHelper> list = new ArrayList<>();
// ...
Collections.sort(list);
希望它可以帮助某人。 :)