ForkJoinPool是Java 7 引入的一种线程池实现,专门用于支持“大规模并行”任务的执行。那么,它和普通的线程池(ThreadPoolExecutor)有什么本质的区别呢?
一、Fork/Join 框架简介:
Fork/Join 框架是一种并行计算框架,设计目的是提高具有递归性质任务的执行速度。典型的任务是将问题逐步分解成较小的任务,直到每一个子任务足够简单可以直接解决,然后再将结果聚合起来。
工作原理
Fork/Join 框架基于"工作窃取"算法 (Work Stealing Algorithm),该算法的核心思想是每个工作线程有自己的任务队列(双端队列, Deque)。当一个线程完成了自己队列中的任务时,便会窃取其他线程队列中的任务执行,这样就不会因为某个线程在等待而浪费 CPU 资源。
具体的工作原理如下:
- 任务拆分:框架会将任务递归地拆分成更小的任务,分别放入不同的队列。
- 工作窃取:每个线程都尝试从队列中取任务执行。当一个线程完成了自己的任务队列后会尝试随机从其他队列拿任务继续执行,保证 CPU 资源尽可能地不闲置。
- 任务合并:线程在执行完任务后,会尝试合并(Join)这些任务的结果,直到获得最终结果。
二、ForkJoin Pool 核心组件
For