map排序

前提:map必须指定类型,比如
正例:Map<String,String> ids = new HashMap<>();

1. 按倒序排序

2. 按key正序排序

3. 或者常见一个新的map

代码如下:

@Test
public void test4() {

    Map<String, Object> result = new HashMap<String, Object>();
    result.put("id", 1);
    result.put("type", "type");
    result.put("key","key");
    result.put("value","value");
    result.put("status",0);
    result.put("createDate", new Date());
    result.put("updateDate",new Date());
    result.put("sort","亚瑟");

    Map<String, Object> finalMap = new LinkedHashMap<>();
    // 1. 按倒序排序
    //result.entrySet().stream()
    //        .sorted(Collections.reverseOrder(Map.Entry.comparingByKey()))
    //        .forEachOrdered(e -> finalMap.put(e.getKey(), e.getValue()));

    // 2. 按key正序排序:
    //result.entrySet().stream()
    //        .sorted(Comparator.comparing(e -> e.getKey()))
    //        .forEachOrdered(e -> finalMap.put(e.getKey(), e.getValue()));
    //
    //System.out.println(finalMap);
    
    // 或者常见一个新的map
    Map<String, Object> finalMapNew = result.entrySet().stream()
            .sorted(Comparator.comparing(e -> e.getKey()))
            .collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue, (oldVal, newVal) -> oldVal, LinkedHashMap::new));

    System.out.println(finalMapNew);
}
posted @ 2022-04-27 15:14  xiexie0812  阅读(134)  评论(0)    收藏  举报