java8 对map按照key排序
场景:
在统计各个时间段上的加班人次的场景中,我们得到各个时段的人次。
但是,结果不是有序的,我们要求的顺序是[0-1],[1-2],[2-3],[3-4]…[23-0]
解决办法:
对map的key,进行分割,取“-”前面的值,按值从小到大排序。
代码实现:
public static void main(String[] args) {
Map<String, Integer> unsortMap = new HashMap<>();
unsortMap.put("6-7", 1);
unsortMap.put("7-8", 1);
unsortMap.put("18-19", 9);
unsortMap.put("17-18", 8);
unsortMap.put("8-9", 1);
unsortMap.put("14-15", 3);
unsortMap.put("13-14", 3);
unsortMap.put("16-17", 3);
unsortMap.put("15-16", 3);
unsortMap.put("12-13", 3);
unsortMap.put("11-12", 2);
unsortMap.put("10-11", 2);
unsortMap.put("9-10", 1);
unsortMap.put("19-20", 8);
unsortMap.put("23-0", 2);
unsortMap.put("0-1", 1);
unsortMap.put("1-2", 1);
unsortMap.put("22-23", 3);
unsortMap.put("2-3", 1);
unsortMap.put("21-22", 6);
unsortMap.put("20-21", 6);
unsortMap.put("3-4", 1);
unsortMap.put("4-5", 1);
unsortMap.put("5-6", 1);
System.out.println(unsortMap);
Map<String, Integer> result1 = unsortMap.entrySet().stream()
.sorted(Map.Entry.comparingByKey(Comparator.comparingInt(o -> Integer.valueOf(o.split("-")[0]))))
.collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue,
(oleValue, newValue) -> oleValue, LinkedHashMap::new));
System.out.println(result1);
}