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