java并行之parallerlStream

微笑、不失礼 提交于 2019-12-05 17:37:56

java并行API演变:

  • 1.0-1.4 中的 java.lang.Thread
  • 5.0 中的 java.util.concurrent
  • 6.0 中的 Phasers 等
  • 7.0 中的 Fork/Join 框架
  • 8.0 中的 parallelStream

 

parallelStream是java 8引入的,用于并行操作。其内部用了Fork/Join框架(借助ForkJoinPool.commonPool()来执行任务)。

适用场景:CPU密集型

为何可比普通的多线程或线程池快:Fork/Join框架将大任务拆解成无交集的子任务给不同线程并行执行,最后汇集结果。与线程池不同的是,还采取了工作窃取(work-stealing)算法,当有线程完成计算任务时会从其他线程取任务来执行,而不是完成就完了。

优点:代码简介,执行效率高;缺点:黑箱、不好跟踪调试

使用:尽可能用Stream API,多核情况下尽可能用parallelStream

 

参考资料:

parallelStream原理:https://github.com/CarpenterLee/JavaLambdaInternals/blob/master/7-ParallelStream.md

Stream API性能测试:https://github.com/CarpenterLee/JavaLambdaInternals/blob/master/8-Stream%20Performance.md

https://blog.csdn.net/u011001723/article/details/52794455

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!