之前将list转map 都是循环 然后逐一添加 效率慢且先不说 主要是代码太冗余 jdk8以后推出了stream流和lambda表达式
ps 请忽略添加测试数据的方式
public static void main(String[] args) {
List<Map<String,Object>> list = new ArrayList<>();
Map<String,Object> map1 = new HashMap<>();
map1.put("id","1");
map1.put("name","张三");
list.add(map1);
Map<String,Object> map2 = new HashMap<>();
map2.put("id","2");
map2.put("name","李四");
list.add(map2);
Map<String,Object> map3 = new HashMap<>();
map3.put("id","3");
map3.put("name","王五");
list.add(map3);
Map<String,Object> map4 = new HashMap<>();
map4.put("id","4");
map4.put("name","张三");
list.add(map4);
// 将list<Map> 转为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 当然第二种方式的写法 也能满足第一种要的结果