list 对象排序的类

本文介绍了一种使用Java实现的通用列表排序方法,该方法通过反射调用对象的getter方法来获取比较值,并支持正序和倒序排序。适用于任何实现了特定getter方法的对象列表。

public class SortList<T> {

/**
* 用于List公共排序的方法
* @param list 排序的List对象
* @param method 需要排序的字段注意如属性是itemNum须要写它的get方法 getItemNum
* @param sort 倒序desc
*/
public void Sort(List<T> 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 = ((T) a).getClass().getMethod(method, null);
Method m2 = ((T) b).getClass().getMethod(method, null);
if (sort != null && "desc".equals(sort))// 倒序
ret = m2.invoke(((T) b), null).toString().compareTo(
m1.invoke(((T) a), null).toString());
else
// 正序
ret = m1.invoke(((T) a), null).toString().compareTo(
m2.invoke(((T) 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<ProcessManage> sorlList=new SortList<ProcessManage>();
sorlList.Sort(pmList, "getItemNum", null); //如倒序desc

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值