JDK8 stream toMap方法介绍

JDK8 List转Map方法,有下3种方法。

java 复制代码
toMap(keyMapper, valueMapper);
toMap(keyMapper, valueMapper, BinaryOperator<U> mergeFunction);
toMap(keyMapper, valueMapper, BinaryOperator<U> mergeFunction, Supplier<M> mapSupplier);

keyMapper:Key的映射函数

valueMapper:Value的映射函数

mergeFunction:当Key冲突时,调用的合并方法,对value进行处理。

mapSupplier:Map 构造器,在需要返回特定的Map时使用

第一个toMap方法

第一个toMap()方法返回Map,自然会需要key和value,所以2个参数是用来生成key和value的,下面案例如果key重复,会有报错

java 复制代码
userList.stream().collect(Collectors.toMap(User::getId, t -> t));
userList.stream().collect(Collectors.toMap(User::getId, Function.identity()));

第二个toMap方法

第二个toMap()方法的第一个参数就是用来生成key值的,第二个参数就是用来生成value值的。第三个参数用在key值冲突的情况下:如果新元素产生的key在Map中已经出现过了,第三个参数就会定义解决的办法。

比如下面:

java 复制代码
collect(Collectors.toMap(UserBo::getUserId, v -> v, (v1, v2) -> v1));

第一个参数UserBo::getUserId 表示选择UserBo的getUserId作为map的key值;

第二个参数v -> v表示选择将原来的对象作为map的value值;

第三个参数(v1, v2) -> v1中,如果v1与v2的key值相同,选择v1作为那个key所对应的value值,注意是key所对应的value。

案例

java 复制代码
List<String> strings = Arrays.asList("a", "b", "c", "a", "b");
// 使用toMap时,通过BinaryOperator函数处理重复键,注意BinaryOperator函数的2个参数是这个key对应的value
Map<String, Integer> map = strings.stream().collect(
		Collectors.toMap(
			str -> str,
			str -> 1,
			(existingValue, newValue) -> existingValue + newValue));
			
//map  {a=2, b=2, c=1}

第三个toMap方法

重点说下第四个参数(mapSupplier)用于自定义返回Map类型,比如我们希望返回的Map是根据 Key 排序的,可以使用如下写法:

java 复制代码
userList.stream().collect(Collectors.toMap(User::getId, User::getName, (n1, n2) -> n1, TreeMap::new));
userList.stream().collect(Collectors.toMap(User::getId, User::getName, (n1, n2) -> n1, LinkedHashMap::new));

注意事项

1、Map中的value不能为null

2、Map中的key不能重复(可以通过第二个toMap或者第三个toMap方法解决)

相关推荐
爱吃土豆的程序员13 天前
java List<Map<String, Object>> 转 List<JSONObject> 的几种方式
java·list·stream·jsonobject·集合转换
bjzhang7519 天前
Springboot开发——IDEA高版本中如何创建JDK8的项目
spring boot·intellij-idea·jdk8
杰克逊的日记2 个月前
JAVA8引入了哪些新特性
java·开发语言·jdk8
追光天使2 个月前
Mac 安装 jdk 8详细教程
java·macos·jdk8
营赢盈英2 个月前
using showdown js with openAi streaming response
开发语言·前端·javascript·stream·openai api
是枫似风3 个月前
消息驱动Stream---基于SpringCloud
java·spring boot·后端·spring·spring cloud·stream·消息分区
法尼的铁帽子3 个月前
stream流与Predicate结合对集合去重或获取重复元素
java·stream·java8
iFlyCai3 个月前
Flutter中的异步编程
flutter·stream·async·future·await·futurebuilder·flutter异步编程
Hello-Brand3 个月前
Redis系列:使用Stream实现消息队列 (图文总结+Go案例)
redis·stream·高性能·高可用·xadd·xread
伊织code3 个月前
python_rtmpstream - Python rtmp 推流
开发语言·python·ffmpeg·stream·推流·rtmp