V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
lanping
V2EX  ›  程序员

java8 的 stream 和 parallStream 原来求解

  •  
  •   lanping · 2019-06-14 10:53:25 +08:00 · 1996 次点击
    这是一个创建于 1973 天前的主题,其中的信息可能已经有所发展或是发生改变。
    stream 是串行流,parallStream 是并行流,底层实现都是 fork/join
    原理是:
    1、stream 是创建一个 ForkJoinTask,parallStream 是创建多个 ForkJoinTask
    2、stream 和 parallStream 都是采用 ForkJoinPool

    是这样的吗?
    4 条回复    2019-06-14 14:18:39 +08:00
    yidinghe
        1
    yidinghe  
       2019-06-14 11:17:06 +08:00
    非 parallStream 对集合元素的处理是在当前线程中进行的,没有用到 ForkJoinPool。
    mazai
        2
    mazai  
       2019-06-14 11:25:58 +08:00
    只有 并行流用到了 forkjoin 框架 串行并没有 底层是通过传递一个 boolean 变量来区分的
    youngsterxyf
        3
    youngsterxyf  
       2019-06-14 12:52:48 +08:00
    可以大致读一下 stream 的源码。stream 串行流只是对源数据的迭代器迭代一遍,应用代码中写的算子(多个算子会嵌套调用)。parallelStream 依赖源数据迭代器的切分方式,将源数据尽量均匀地切分成多份,然后基于 forkjoin 框架来并行处理。并行流的成本还是有点高的,所以对于小数据量不要随便使用。
    lanping
        4
    lanping  
    OP
       2019-06-14 14:18:39 +08:00
    感谢指点
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1697 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 16:49 · PVG 00:49 · LAX 08:49 · JFK 11:49
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.