java 中 List<T>如何按照T中的一个字段排序?

其中T是一个自定义的对象,T中包含好多个字段,我想通过该对象中的一个字段排序,使用Comparator好像仅能对T进行排序而不能到达里面的字段,希望高手能够提供详细实现代... 其中T是一个自定义的对象,T中包含好多个字段,我想通过该对象中的一个字段排序,使用Comparator好像仅能对T进行排序而不能到达里面的字段,希望高手能够提供详细实现代码 展开
 我来答
198901245631
推荐于2016-01-26 · TA获得超过3.5万个赞
知道大有可为答主
回答量:9037
采纳率:92%
帮助的人:1725万
展开全部
可以通过以下工具类进行实现:
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
/**
* List按照指定字段排序工具类
*
* @param <T>
*/
public class ListSortUtil<T> {
/**
* @param targetList 目标排序List
* @param sortField 排序字段(实体类属性名)
* @param sortMode 排序方式(asc or desc)
*/
@SuppressWarnings({ "unchecked", "rawtypes" })
public void sort(List<T> targetList, final String sortField, final String sortMode) {

Collections.sort(targetList, new Comparator() {
public int compare(Object obj1, Object obj2) {
int retVal = 0;
try {
//首字母转大写
String newStr=sortField.substring(0, 1).toUpperCase()+sortField.replaceFirst("\\w","");
String methodStr="get"+newStr;

Method method1 = ((T)obj1).getClass().getMethod(methodStr, null);
Method method2 = ((T)obj2).getClass().getMethod(methodStr, null);
if (sortMode != null && "desc".equals(sortMode)) {
retVal = method2.invoke(((T) obj2), null).toString().compareTo(method1.invoke(((T) obj1), null).toString()); // 倒序
} else {
retVal = method1.invoke(((T) obj1), null).toString().compareTo(method2.invoke(((T) obj2), null).toString()); // 正序
}
} catch (Exception e) {
throw new RuntimeException();
}
return retVal;
}
});
}

}

Collections.sort(list.);//升序
flyingFish211
2011-09-19 · TA获得超过2.1万个赞
知道大有可为答主
回答量:1.5万
采纳率:50%
帮助的人:1.1亿
展开全部
class TComparator implements Comparator<T>{

public int compare(T o1, T o2) {

Object field1 = o1.getField();//要比较的T得字段
Object fiel2 = o2.getField();//要比较的字段
return field1 > field2 ? 1: -1;//根据字段比较结果返回1(>)或者-1(<)
}

}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
风铃剑侠
推荐于2016-03-21 · TA获得超过1145个赞
知道小有建树答主
回答量:781
采纳率:0%
帮助的人:977万
展开全部
package list;

import java.util.ArrayList;
import java.util.Collections;

//这是关于List用法,代表性的有LinkedList,ArrayList,Vector用法类似
//排序
//Collections可以排序,还可以得到最大,最小数值,还可以将集合反转
public class SortListTest {

/**
* @param args
*/
@SuppressWarnings("unchecked")
public static void main(String[] args) {
ArrayList list = new ArrayList();

//添加
list.add(45);
list.add(67);
list.add(87);
list.add(23);
list.add(67);

Collections.sort(list);//升序
//Collections.sort(list,Collections.reverseOrder());//降序

//遍历
int size = list.size();
for ( int i=0; i<size; i++ )
{
Integer str =(Integer)list.get(i);//得到某个位置的元素
System.out.println(str);
}
}

}

望采纳
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
柏新星
2011-09-19 · TA获得超过131个赞
知道小有建树答主
回答量:226
采纳率:0%
帮助的人:155万
展开全部
你是说的用java 操作数据库吗
如果是的话 你可以在 你的 sql语句后面加上 order by ‘字段’
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式