Comparator用法
一直以来我还从未自己写过自定义排序,以前以为只要集合中的对象实现Comparable就可以了,所以一直没动手做,今天碰到了,让我头疼了好久
,其实关于自定义排序,用的最多的无非Comparator与Comparable了,我相信Comparable大家应该用的很熟悉,Comparator其实跟able一样,实现一个Compare方法,这个里面写自定义实现的方法
List<Map<String,Object>> list = Lists.newArrayListWithCapacity(page_size);
HashMap<String, Object> map;
int i = 1;
while (i <= page_size&&resultSet.next()) {
map = new HashMap<String, Object>();
map.put("zh_label",resultSet.getString("zh_label"));
map.put("project_no",resultSet.getString("project_num"));
map.put("state",resultSet.getString("state"));
map.put("progress",resultSet.getString("progress"));
i++;
list.add(map);
}
Collections.sort(list,new Comparator<Map<String,Object>>(){
@Override
public int compare(Map<String, Object> o1, Map<String, Object> o2) {
if (o1.get("state").equals("未完成")||o1.get("state").equals("已完成")&&!o2.get("state").equals("未完成")){
return -1;
}else{
return 1;
}
}
Collections.sort(list,Comparator