//通用排序
public class SortList<E> {
public void Sort(List<E> list, final String method, final String sort) {
Collections.sort(list, new Comparator() {
public int compare(Object a, Object b) {
int ret = 0;
try {
Method m1 = ((E) a).getClass().getMethod(method, null);
Method m2 = ((E) b).getClass().getMethod(method, null);
if (sort != null && "desc".equals(sort))// 倒序
ret = m2.invoke(((E) b), null).toString().compareTo(
m1.invoke(((E) a), null).toString());
else
// 正序
ret = m1.invoke(((E) a), null).toString().compareTo(
m2.invoke(((E) b), null).toString());
} catch (NoSuchMethodException ne) {
System.out.println(ne);
} catch (IllegalAccessException ie) {
System.out.println(ie);
} catch (InvocationTargetException it) {
System.out.println(it);
}
return ret;
}
});
}
}
调用:
SortList<TbNews> sortList = new SortList<TbNews>();
// 排序 list为集合,getNdate根据哪个字段排序,desc排序方式
sortList.Sort(list, "getNdate", "desc");
本文介绍了一个Java通用列表排序方法,该方法可以根据指定的方法名和排序方式(升序或降序)对任意类型的列表进行排序。通过反射机制获取并比较对象属性实现排序。
2132

被折叠的 条评论
为什么被折叠?



