通过stream流 将 List 转为 Map

之前将list转map 都是循环  然后逐一添加  效率慢且先不说  主要是代码太冗余  jdk8以后推出了stream流和lambda表达式

ps 请忽略添加测试数据的方式

public static void main(String[] args) {

        List> list = new ArrayList<>();

        Map map1 = new HashMap<>();
        map1.put("id","1");
        map1.put("name","张三");
        list.add(map1);

        Map map2 = new HashMap<>();
        map2.put("id","2");
        map2.put("name","李四");
        list.add(map2);

        Map map3 = new HashMap<>();
        map3.put("id","3");
        map3.put("name","王五");
        list.add(map3);

        Map map4 = new HashMap<>();
        map4.put("id","4");
        map4.put("name","张三");
        list.add(map4);

        // 将list 转为Map 效果如下
        // 第一种 (如果key重复 会覆盖上一个value)
        // 输出结果 李四={name=李四, id=2}, 张三={name=张三, id=4}, 王五={name=王五, id=3}
        System.out.println(list.stream().collect(HashMap::new, (m, e) -> m.put(e.get("name").toString(), e), HashMap::putAll).toString());

        // 第二种 (如果key重复 不会覆盖上一个value)
        // 输出结果 李四={name=李四, id=2}, 张三={name=张三, id=1}, 王五={name=王五, id=3}
        System.out.println(list.stream().collect(Collectors.toMap(k -> (String) k.get("name"), v -> v, (a, b) -> a)).toString());
    }

ps 当然第二种方式的写法  也能满足第一种要的结果

你可能感兴趣的:(list,stream,lambda,map,java)