java8 的 stream 和 parallStream 原来求解

2019-06-14 10:53:25 +08:00
 lanping
stream 是串行流,parallStream 是并行流,底层实现都是 fork/join
原理是:
1、stream 是创建一个 ForkJoinTask,parallStream 是创建多个 ForkJoinTask
2、stream 和 parallStream 都是采用 ForkJoinPool

是这样的吗?
2008 次点击
所在节点    程序员
4 条回复
yidinghe
2019-06-14 11:17:06 +08:00
非 parallStream 对集合元素的处理是在当前线程中进行的,没有用到 ForkJoinPool。
mazai
2019-06-14 11:25:58 +08:00
只有 并行流用到了 forkjoin 框架 串行并没有 底层是通过传递一个 boolean 变量来区分的
youngsterxyf
2019-06-14 12:52:48 +08:00
可以大致读一下 stream 的源码。stream 串行流只是对源数据的迭代器迭代一遍,应用代码中写的算子(多个算子会嵌套调用)。parallelStream 依赖源数据迭代器的切分方式,将源数据尽量均匀地切分成多份,然后基于 forkjoin 框架来并行处理。并行流的成本还是有点高的,所以对于小数据量不要随便使用。
lanping
2019-06-14 14:18:39 +08:00
感谢指点

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/573833

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX