1. 要求
对列表(List)中的自定义对象,要求能够按照对象的属性(字段)进行排序(正序、倒序)。
如:用户对象(Member)有用户名(username)、级别(level)、出生日期(birthday)等字段,要求可以分别对它的三个字段进行排序。
2. 实现思路
1. 对于自定义对象,可以在自定义对象中实现Comparable接口,然后再调用Collections.sort的方法实现排序,只能是针对一个属性(字段),维持一个顺序;要实多字段任意选择一个排序,同样需要通过调用Collections.sort(List<T> list, Comparator<? super T> c)方法,传进一个Comparator来实现。
2. 为避免上述步骤中复杂且重复的代码,可以写一个通用的排序类,能够对自定义对象,针对不同的属性(字段),实现排序(正序、倒序)。
3. 实现代码
member类
package com.clzhang.sample.collections;import java.text.SimpleDateFormat;import java.util.Date;/** * 测试用实体类 * @author acer * */public class Member implements Comparable{ // 格式化日期用 private static final SimpleDateFormat MY_SDF = new SimpleDateFormat( "yyyy-MM-dd"); // 几个属性 private int id; private String username; private int level; private Date birthday; // 构造函数 public Member(int id, String username, int level, String birthday) throws Exception { this.id = id; this.username = username; this.level = level; this.birthday = new Date(MY_SDF.parse(birthday).getTime()); } // Getters public String getUsername() { return username; } public int getLevel() { return level; } public Date getBirthday() { return birthday; } // 返回打印用 @Override public String toString() { return id + "|" + username + "|" + level + "|" + MY_SDF.format(birthday); } // 注意:如果使用MySortList类,则此方法不再需要。因为此方法是提供给Collections.sort方法使用的。 @Override public int compareTo(Member m) { // 只能对一个字段做比较,如果做整个对象的比较就实现不了按指定字段排序了。 return this.getUsername().compareTo(m.getUsername()); }}
MySortList类
package com.clzhang.sample.collections;import java.util.*;import java.lang.reflect.Method;import java.lang.reflect.InvocationTargetException;/** * 这是一个自定义排序的类,专门针对列表(List)中的数据进行排序;可按指定方法进行。 * 目前实现对字符串(String)、日期(Date)、整型(Integer)等三种对象进行排序。 * @author acer * * @param*/public class MySortList { /** * 对列表中的数据按指定字段进行排序。要求类必须有相关的方法返回字符串、整型、日期等值以进行比较。 * @param list * @param method * @param reverseFlag */ public void sortByMethod(List list, final String method, final boolean reverseFlag) { Collections.sort(list, new Comparator
在对不同字段排序时,发现调坑了,
要这样写
List<WorksheetTypeColumn dflist = worksheetTypeColumnService.findColumnList(worksheetTypeColumn);
// 生成自定义对象,然后对它按照指定字段排序 MySortList<WorksheetTypeColumn> msList = new MySortList<WorksheetTypeColumn>(); msList.sortByMethod(dflist, "getQuerySort", false); List<WorksheetTypeColumn> qsList = Lists.newArrayList(); qsList.addAll(dflist);不能qsList=dflist,切记
model.addAttribute("qsList", qsList); msList.sortByMethod(dflist, "getListSort", false); List<WorksheetTypeColumn> lsList = Lists.newArrayList(); lsList.addAll(dflist);不能lsList=dflist,切记
model.addAttribute("lsList", lsList);qsList=dflist的后果是qsList和lsList的内容的顺序一样