Map根据key排序
升序
Demo代码:
//使用TreeMap
Map<Integer, String> map = new TreeMap<>();
map.put(10, "第10名次");
map.put(15, "第15名次");
map.put(1, "第1名次");
map.put(5, "第5名次");
map.put(3, "第3名次");
map.put(8, "第8名次");
System.out.println(map.toString());
运行结果:
{1=第1名次, 3=第3名次, 5=第5名次, 8=第8名次, 10=第10名次, 15=第15名次}
如上所示,TreeMap会根据key值进行排序,默认是升序(注:TreeMap不会根据Value值进行排序)。
降序
Demo代码:
//使用TreeMap,并自定义比较器
Map<Integer, String> map = new TreeMap<>(new Comparator<Integer>() {@Overridepublic int compare(Integer o1, Integer o2) {return o2.compareTo(o1);}
});
map.put(10, "第10名次");
map.put(15, "第15名次");
map.put(1, "第1名次");
map.put(8, "第8名次");
System.out.println(map.toString());
运行结果:
{15=第15名次, 10=第10名次, 8=第8名次, 1=第1名次}
Map根据Value排序
Demo代码:
Map<String, List<String>> valMap = new HashMap<>();
//初始化值
List<String> valList1 = new ArrayList<>();
valList1.add("val1");
valList1.add("val2");
valList1.add("val3");
valList1.add("val4");
List<String> valList2 = new ArrayList<>();
valList2.add("val1");
valList2.add("val2");
List<String> valList3 = new ArrayList<>();
valList3.add("val1");
valList3.add("val2");
valList3.add("val3");
valList3.add("val4");
valList3.add("val5");
valList3.add("val6");
valList3.add("val7");
List<String> valList4 = new ArrayList<>();
valList4.add("val1");
//赋值
valMap.put("key1", valList1);
valMap.put("key2", valList2);
valMap.put("key3", valList3);
valMap.put("key4", valList4);
//将Map转为List
ArrayList<Entry<String, List<String>>> list = new ArrayList<>(valMap.entrySet());
//排序,自定义比较器,根据value值进行降序
list.sort(new Comparator<Entry<String, List<String>>>() {@Overridepublic int compare(Entry<String, List<String>> o1, Entry<String, List<String>> o2) {Integer o1Int = o1.getValue().size();Integer o2Int = o2.getValue().size();return o2Int.compareTo(o1Int);}
});
System.out.println(list);
运行结果:
[key3=[val1, val2, val3, val4, val5, val6, val7], key1=[val1, val2, val3, val4], key2=[val1, val2], key4=[val1]]