# java stream
中 Collectors
的用法
-
java stream
中Collectors
的用法- 简介
-
Collectors.toList()
-
Collectors.toSet()
-
Collectors.toCollection()
-
Collectors.toMap()
-
Collectors.collectingAndThen()
-
Collectors.joining()
-
Collectors.counting()
-
Collectors.summarizingDouble/Long/Int()
-
Collectors.averagingDouble/Long/Int()
-
Collectors.summingDouble/Long/Int()
-
Collectors.maxBy()/minBy()
-
Collectors.groupingBy()
-
Collectors.partitioningBy()
# 简介
在 java stream
中,我们通常需要将处理后的 stream
转换成集合类,这个时候就需要用到 stream.collect
方法。 collect
方法需要传入一个 Collector
类型,要实现 Collector
还是很麻烦的,需要实现好几个接口。
于是 java
提供了更简单的 Collectors
工具类来方便我们构建 Collector
。
下面我们将会具体讲解 Collectors
的用法。
假如我们有这样两个 list:
1 | List<String> list = Arrays.asList("jack", "bob", "alice", "mark"); |
上面一个是无重复的 list
,一个是带重复数据的 list
。接下来的例子我们会用上面的两个 list
来讲解 Collectors
的用法。
# Collectors.toList()
1 | List<String> listResult = list.stream().collect(Collectors.toList()); |
data:image/s3,"s3://crabby-images/4b254/4b254d82fbaf5ed72be04ae8b6abc449cdf7d6c7" alt=""
将 stream
转换为 list
。这里转换的 list
是 ArrayList
,如果想要转换成特定的 list
,需要使用 toCollection
方法。
# Collectors.toSet()
1 | Set<String> setResult = list.stream().collect(Collectors.toSet()); |
data:image/s3,"s3://crabby-images/ce547/ce547a151e6a4f1906cefd7e9a4aa9ac68362862" alt=""
# Collectors.toCollection()
上面的 toMap,toSet
转换出来的都是特定的类型,如果我们需要自定义,则可以使用 toCollection()
1 | List<String> custListResult = list.stream().collect(Collectors.toCollection(LinkedList::new)); |
data:image/s3,"s3://crabby-images/5e0f0/5e0f00efe782d45ad73b989e3e39182c14c93ac4" alt=""
# Collectors.toMap()
toMap
接收两个参数,第一个参数是 keyMapper
,第二个参数是 valueMapper
:
1 | Map<String, Integer> mapResult = list.stream() |
如果 stream
中有重复的值,则转换会报 IllegalStateException
异常:
1 | Map<String, Integer> duplicateMapResult = duplicateList.stream() |
data:image/s3,"s3://crabby-images/3959d/3959d8ee5f5ca086c0fda04984694c05527abe04" alt=""
解决方案:
1 | Map<String, Integer> duplicateMapResult2 = duplicateList.stream() |
在 toMap
中添加第三个参数 mergeFunction
,来解决冲突的问题。
data:image/s3,"s3://crabby-images/d5842/d584241ceee62fa5c41c6e0ee8d60ac41e410b94" alt=""
# Collectors.collectingAndThen()
collectingAndThen
允许我们对生成的集合再做一次操作。
1 | List<String> collectAndThenResult = list.stream() |
data:image/s3,"s3://crabby-images/c6975/c6975ca2c4d2bf796c98fe13fea118665796d868" alt=""
# Collectors.joining()
Joining
用来连接 stream
中的元素:
1 | String joinResult = list.stream().collect(Collectors.joining()); |
data:image/s3,"s3://crabby-images/4615a/4615a01b2dcfc52a64432cb78baa56cba53016a8" alt=""
可以不带参数,也可以带一个参数,也可以带三个参数,根据我们的需要进行选择。
# Collectors.counting()
counting
主要用来统计 stream
中元素的个数:
1 | Long countResult = list.stream().collect(Collectors.counting()); |
data:image/s3,"s3://crabby-images/6a68c/6a68c88c5a68923efc0374072f11f7ba1fab101c" alt=""
# Collectors.summarizingDouble/Long/Int()
SummarizingDouble/Long/Int
为 stream
中的元素生成了统计信息,返回的结果是一个统计类:
1 | IntSummaryStatistics intResult = list.stream() |
data:image/s3,"s3://crabby-images/b0431/b04318e838de380f93daf70cf91484d5209dc17a" alt=""
# Collectors.averagingDouble/Long/Int()
averagingDouble/Long/Int()
对 stream
中的元素做平均:
1 | Double averageResult = list.stream().collect(Collectors.averagingInt(String::length)); |
data:image/s3,"s3://crabby-images/f5661/f56616399b5302075554d182c3f3c5ee72358ca8" alt=""
# Collectors.summingDouble/Long/Int()
summingDouble/Long/Int()
对 stream
中的元素做 sum
操作:
1 | Double summingResult = list.stream().collect(Collectors.summingDouble(String::length)); |
data:image/s3,"s3://crabby-images/4a356/4a3566bb5f02b5de88ddba66f76d10d526d152b7" alt=""
# Collectors.maxBy()/minBy()
maxBy()/minBy()
根据提供的 Comparator
,返回 stream
中的最大或者最小值:
1 | Optional<String> maxByResult = list.stream().collect(Collectors.maxBy(Comparator.naturalOrder())); |
data:image/s3,"s3://crabby-images/2c61a/2c61a3da21430d69721e7d3a608114db81a5e9d7" alt=""
# Collectors.groupingBy()
GroupingBy
根据某些属性进行分组,并返回一个 Map
:
1 | Map<Integer, Set<String>> groupByResult = list.stream() |
data:image/s3,"s3://crabby-images/b65a5/b65a517a50e1776b0a0fc657b920b6192df99fac" alt=""
# Collectors.partitioningBy()
PartitioningBy
是一个特别的 groupingBy,PartitioningBy
返回一个 Map
,这个 Map
是以 boolean
值为 key
,从而将 stream
分成两部分,一部分是匹配 PartitioningBy
条件的,一部分是不满足条件的:
data:image/s3,"s3://crabby-images/7fe55/7fe55fe2b3a28efed683939acfc5aff862463d1f" alt=""