52.Fork & Join线程池

作者 : admin 本文共509个字,预计阅读时间需要2分钟 发布时间: 2024-06-8 共3人阅读

介绍

jdk1.7之后加入的新的线程池的实现。

实现一种分治的思想。

适用于能够进行任务拆分的cpu密集型运算。

任务拆分

将一个大任务拆分为算法上相同的小任务,直至不能拆分可以直接求解。例如跟递归相关的一些计算,如归并排序、斐波那契数列都可以利用分治的思想。

Fork/Join是在分治的思想上加了多线程。可以把每个任务的分解和合并交给不同的线程来完成。进一步提升了运算效率。

Fork/Join默认会创建于cpu核心数大小相同的线程池。

案例:求1+2+3+…+n的和?

//RecursiveTask 递归任务-有返回值的
//RecursiveAction 递归任务-没有返回值
@Slf4j
class MyTask extends RecursiveTask {
    private int n;

    public MyTask(int n) {
        this.n = n;
    }

    @Override
    public String toString() {
        return "MyTask{" +
                "n=" + n +
                '}';
    }

    //计算1-n之间整数的和
    @Override
    protected Integer compute() {
        if(n == 1) {
            //终止条件
            log.debug("join() {}", n);
  
本站无任何商业行为
个人在线分享 » 52.Fork & Join线程池
E-->