JUC分支合并框架Fork和Join用法

Fork/Join它可以将一个大的任务拆分成多个子任务进行并行处理,最后将子任务结果合并成最后的计算结果,

并进行输出,Fork/Join框架要完成两件事情:

Fork: 把一个复杂任务进行拆分,大事化小

Join: 把拆分任务的结果进行合并。

 

 

 

代码如下:

class MyTask extends RecursiveTask<Integer> {
    //拆分差值不能超过10,计算10以内运算
    private static final Integer VALUE = 10;
    private int begin; //拆分开始值
    private int end; //拆分结束值
    private int result; //返回结果

    public MyTask(int begin, int end) {
        this.begin = begin;
        this.end = end;
    }

    @Override
    protected Integer compute() {
        //判断相加两个数值是否大于10
        if((end - begin) <= VALUE) {
            for(int i = begin; i <= end; i++) {
                result = result + i;
            }
        } else { //进一步拆分
            //获取中间值
            int middle = (begin + end) / 2;
            //拆分左边
            MyTask task01 = new MyTask(begin,middle);
            //拆分右边
            MyTask task02 = new MyTask(middle + 1,end);
            //调用方法拆分
            task01.fork();
            task02.fork();
            //合并结果
            result = task01.join() + task02.join();

        }
        return result;
    }
}

public class ForkJoinDemo {
    public static void main(String []args) throws ExecutionException, InterruptedException {
        MyTask myTask = new MyTask(0,100);
        //创建分支合并池对象
        ForkJoinPool forkJoinPool = new ForkJoinPool();
        ForkJoinTask<Integer> forkJoinTask = forkJoinPool.submit(myTask);

        //获取最终合并之后结果
        Integer result = forkJoinTask.get();
        System.out.println(result);
    }
}

结果如下:

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章