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);
}
欢迎一起来学习和指导,谢谢关注!
本文来自博客园,作者:xiexie0812,转载请注明原文链接:https://www.cnblogs.com/mask-xiexie/p/16199048.html
                
            
        
浙公网安备 33010602011771号