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

其中T是一个自定义的对象,T中包含好多个字段,我想通过该对象中的一个字段排序,使用Comparator好像仅能对T进行排序而不能到达里面的字段,希望高手能够提供详细实现代码

可以通过以下工具类进行实现:
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.);//升序
温馨提示:答案为网友推荐,仅供参考
第1个回答  2011-09-19
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(<)
}

}
第2个回答  推荐于2016-03-21
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);
}
}

}

望采纳本回答被提问者采纳
第3个回答  2011-09-19
你是说的用java 操作数据库吗
如果是的话 你可以在 你的 sql语句后面加上 order by ‘字段’
相似回答