时间:2021-05-20
本文实例讲述了Java Stream 流实现合并操作。分享给大家供大家参考,具体如下:
Java Stream Api 提供了很多有用的 Api 让我们很方便将集合或者多个同类型的元素转换为流进行操作。今天我们来看看如何合并 Stream 流。
Stream 流合并的前提是元素的类型能够一致。
最简单合并流的方法是通过 Stream.concat() 静态方法:
Stream<Integer> stream = Stream.of(1, 2, 3);Stream<Integer> another = Stream.of(4, 5, 6);Stream<Integer> concat = Stream.concat(stream, another);List<Integer> collect = concat.collect(Collectors.toList());List<Integer> expected = Lists.list(1, 2, 3, 4, 5, 6);Assertions.assertIterableEquals(expected, collect);这种合并是将两个流一前一后进行拼接:
多个流的合并我们也可以使用上面的方式进行“套娃操作”:
Stream.concat(Stream.concat(stream, another), more);你可以一层一层继续套下去,如果需要合并的流多了,看上去不是很清晰。
我之前介绍过一个Stream 的 flatmap 操作 ,它的大致流程可以参考里面的这一张图:
因此我们可以通过 flatmap 进行实现合并多个流:
Stream<Integer> stream = Stream.of(1, 2, 3);Stream<Integer> another = Stream.of(4, 5, 6);Stream<Integer> third = Stream.of(7, 8, 9);Stream<Integer> more = Stream.of(0);Stream<Integer> concat = Stream.of(stream,another,third,more). flatMap(integerStream -> integerStream);List<Integer> collect = concat.collect(Collectors.toList());List<Integer> expected = Lists.list(1, 2, 3, 4, 5, 6, 7, 8, 9, 0);Assertions.assertIterableEquals(expected, collect);这种方式是先将多个流作为元素生成一个类型为 Stream<Stream<T>> 的流,然后进行 flatmap 平铺操作合并。
有很多第三方的强化库 StreamEx 、Jooλ 都可以进行合并操作。另外反应式编程库 Reactor 3 也可以将 Stream 流合并为反应流,在某些场景下可能会有用。这里演示一下:
List<Integer> block = Flux.fromStream(stream) .mergeWith(Flux.fromStream(another)) .collectList() .block();如果你经常使用 Java Stream Api ,合并 Stream 流是经常遇到的操作。
更多关于java算法相关内容感兴趣的读者可查看本站专题:《Java文件与目录操作技巧汇总》、《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》和《Java缓存操作技巧汇总》
希望本文所述对大家java程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在这篇文章里,我们将提供Java8Streamdistinct()示例。distinct()返回由该流的不同元素组成的流。distinct()是Stream接口
java流操作对文件的分割和合并的实例详解学习文件的输入输出流,自己做一个小的示例,对文件进行分割和合并。下面是代码:packagecom.dufy.file;
摘要:本文介绍了Java8中流的几个特性,以告诫开发者流并不是高性能的代名词,需谨慎使用流。以下是译文。流(Stream)是Java8为了实现最佳性能而引入的一
stream初体验stream是java8中操作集合的一个重要特性,我们先来看看java里面是怎么定义stream的:"asequenceofelementss
什么是Stream流?Stream流是数据渠道,用于操作数据源(集合、数组等)所生成的元素序列。Stream的优点:声明性,可复合,可并行。这三个特性使得str