在java的众多Map实现中,Map基本上是不能保证顺序的(LinkedHashMap可以保证插入顺序或者访问顺序,TreeMap默认按照key升序但可以自定义Comparator),在开发过程中当数据量不是很大的时候,使用HashMap去统计数据非常方便,但是为了使得输出结果更美观一些,我们需要按某种自定义顺序输出。
下面介绍一种排序Map的方法,使用起来很方便,如下面代码:
private static class ValueComparator implements Comparator<Map.Entry<String, Integer>> { @Override
public int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) {
return o1.getValue() - o2.getValue();
}
} public static void test3() {
Map<String, Integer> map = new HashMap<>();
map.put("a", 9);
map.put("b", 8);
map.put("c", 7);
map.put("d", 6);
map.put("e", 5);
map.put("f", 4);
map.put("g", 3);
map.put("h", 2);
map.put("i", 1); List<Map.Entry<String, Integer>> mapList = new ArrayList<>();
mapList.addAll(map.entrySet());
for (Map.Entry<String, Integer> entry : mapList) {
System.out.println(entry.getKey() + " : " + entry.getValue());
}
System.out.println("\n"); ValueComparator valueComparator = new ValueComparator();
Collections.sort(mapList, valueComparator);
for (Map.Entry<String, Integer> entry : mapList) {
System.out.println(entry.getKey() + " : " + entry.getValue());
}
System.out.println("\n");
}
在上面代码中我们先定义一个Comparator,然后将Map转换为List,通过Collections.sort(mapList, valueComparator)方法进行排序输出。
这种写法还可以简化一下,Comparator使用的时候才定义。
Comparator<Map.Entry<String, Integer>> comparator = new Comparator<Map.Entry<String, Integer>>() {
@Override
public int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) {
return o1.getKey().compareToIgnoreCase(o2.getKey());
}
}; Collections.sort(mapList, comparator);
for (Map.Entry<String, Integer> entry : mapList) {
System.out.println(entry.getKey() + " : " + entry.getValue());
}
使用Java 8之后还可以使用lambda表达式简化一下代码
Comparator<Map.Entry<String, Integer>> comparator = (o1, o2) -> o1.getKey().compareToIgnoreCase(o2.getKey()); Collections.sort(mapList, comparator);
for (Map.Entry<String, Integer> entry : mapList) {
System.out.println(entry.getKey() + " : " + entry.getValue());
}