本文共 3119 字,大约阅读时间需要 10 分钟。
Collectors作为一个提供常用collector的静态方法类,里面的有很多公共的静态方法,大多数方法是借助new CollectorImpl来实现的,少数是借助reducing方法来实现的,不过reducing方法最终也是通过new CollectorImpl来实现的,本节先介绍toCollections和joining两类
这个方法是大家最常用的方法,作用是将流转换成ArrayList,它的组成是
supplier | accumulator | combiner | finisher | characteristic |
---|---|---|---|---|
(Supplier<List>) ArrayList::new | List::add | (left, right) -> { left.addAll(right); return left; } | CH_ID | |
提供的就是一个空的ArrayList容器 | 是将当前的元素T加入到之前的结果容器ArrayList里 | 对于两个结果容器,需要保证顺序,所以返回的是两个容器addAll之后的结果 | IDENTITY_FINISH,不调用finisher方法,得到ArrayList之后不做多余的转换 |
这个方法就是将流里面的元素放到一个Set里面,跟toList() 的区别就是容器的类型不一样
supplier | accumulator | combiner | finisher | characteristic |
---|---|---|---|---|
(Supplier<Set>) HashSet::new | Set::add | (left, right) -> { left.addAll(right); return left; } | CH_UNORDERED_ID | |
提供的就是一个空的HashSet容器 | 是将当前的元素T加入到之前的结果容器HashSet里 | 对于两个结果容器,返回的是两个容器addAll之后的结果 | IDENTITY_FINISH,UNORDERED不调用finisher方法,得到ArrayList之后不做多余的转换,而且操作可以是无序的 |
这方法是可以将流里面的元素放到一个集合容器里,具体的什么类型的集合容器需要传参数来决定,因为上面的两个方法是经常会用到的容器的类型所以具体话了,对于其他没有那么经常使用的集合类型,比如LinkedList,TreeSet之类的可以自己传参来定义。
方法签名:public static> Collector toCollection(Supplier collectionFactory)
supplier | accumulator | combiner | finisher | characteristic |
---|---|---|---|---|
collectionFactory | Collection::add | (r1, r2) -> { r1.addAll(r2); return r1; } | CH_ID | |
提供的容器是用户传入的类型,必须是Collection的子类 | 是将当前的元素T加入到之前的结果容器HashSet里 | 对于两个结果容器,返回的是两个容器addAll之后的结果 | IDENTITY_FINISH,不调用finisher方法,得到ArrayList之后不做多余的转换 |
这个方法可以将流中的元素转换成String拼接起来,中间是没有任何符号和空格的
比如:Streamstream = Stream.of("hello", "world"); System.out.println(stream.collect(Collectors.joining()));
输出:helloworld
先来看这个方法的泛型类型
CollectorImpl<CharSequence, StringBuilder, String>
流中的元素T是CharSequence, 中间结果容器是StringBuilder,最后返回的结果是String类型的
supplier | accumulator | combiner | finisher | characteristic |
---|---|---|---|---|
StringBuilder::new | StringBuilder::append | (r1, r2) -> { r1.append(r2); return r1; } | StringBuilder::toString | CH_NOID |
提供的容器是StringBuilder | 是将当前的元素T append到中间的StringBuilder的尾部 | 对于两个stringBuilder,返回的是两个StringBuilder append之后的结果 | 最后转换成string | Collections.emptySet(),一个空集合,去掉IDENTITY_FINISH是因为这里有finisher方法 |
这个方法也是将元素拼接成String,泛型类型跟上个方法一样,相比之下多了一个功能,可以传入一个参数,代表两个元素中间用这个分隔符来分开,比如,如果希望中间的两个元素是用“-"分开的,那么这个参数就是“-“
Streamstream = Stream.of("hello", "world"); System.out.println(stream.collect(Collectors.joining("—")));
输出:hello-world
具体的实现是调用了另一个重载的方法,这个方法的第一个参数是delimiter,也就是分隔符,具体的我们再下一个方法介绍return joining(delimiter, "", "");
这个拼接的方法功能更丰富一点,除了可以自定义分隔符还可以定义前缀和后缀,
比如:Streamstream = Stream.of("hello", "world"); System.out.println(stream.collect(Collectors.joining("-", "start", "end")));
输出:starthello-worldend
具体的实现是
supplier | accumulator | combiner | finisher | characteristic |
---|---|---|---|---|
() -> new StringJoiner(delimiter, prefix, suffix) | StringJoiner::add | StringJoiner::merge | StringJoiner::toString | CH_NOID |
提供的容器是StringJoiner,所以具体的实现可以去看StringJoiner | 是将当前的元素T add到中间的StringJoiner的尾部 | 对于两个StringJoiner,返回的是两个StringJoiner merge之后的结果 | 最后转换成string | Collections.emptySet() |
转载地址:http://ljvzb.baihongyu.com/