1. 需求描述
一个List 里面 装了 很多的 Map
HashMap<String, Object> map = new HashMap<String, Object>();
map.put("name", "gjk");
map.put("id", "1");
map.put("num", 45);
list.add(map);
HashMap<String, Object> map2 = new HashMap<String, Object>();
map2.put("name", "gjk2");
map2.put("id", "2");
map2.put("num", 60);
list.add(map2);
HashMap<String, Object> map3 = new HashMap<String, Object>();
map3.put("name", "gjk3");
map3.put("id", "3");
map3.put("num", 30);
list.add(map3);
我需要 用num 作为 排序的 依据,如果 两个 num 相同 那么 就比较 那么的
Collections.sort(list, new Comparator<HashMap<String, Object>>() {
@Override
public int compare(HashMap<String, Object> map, HashMap<String, Object> map2) {
//首先比较出现次数,如果相同,则比较名字
Integer num = Integer.parseInt(map.get("num").toString());
Integer num2 = Integer.parseInt(map2.get("num").toString());
int flag = num2.compareTo(num);
if(flag == 0){
return (map2.get("name").toString()).compareTo(map.get("name").toString());
}else{
return flag;
}
}
} );
num 和 num2 可以 对调,调整 顺序