Java并发编程-分而治之:Fork&Join线程池

2018-09-12  本文已影响21人  agile4j

参考资料:《实战Java高并发程序设计》


1. 简介

2.ForkJoinPool 和 ForkJoinTask

public <T> ForkJoinTask<T> submit(ForkJoinTask<T> task)
  1. RecursiveAction没有返回值的任务
  2. RecursiveTask携带返回值的任务
public class Test {

    public static class CountTask extends RecursiveTask<Long> {
        private static final int THRESHOLD = 10000;
        private long start;
        private long end;

        public CountTask(long start, long end) {
            this.start = start;
            this.end = end;
        }

        @Override
        protected Long compute() {
            long sum = 0;
            boolean canCompute = (end - start) < THRESHOLD;
            if (canCompute) {
                for (long i = start; i <= end; i++) {
                    sum += i;
                }
            } else {
                // 分成100个小任务
                long step = (start + end) / 100;
                ArrayList<CountTask> subTasks = new ArrayList<>();
                long pos = start;
                for (int i = 0; i < 100; i++) {
                    long lastOne = pos + step;
                    if (lastOne > end) {
                        lastOne = end;
                    }
                    CountTask subTask = new CountTask(pos, lastOne);
                    pos += step + 1;
                    subTasks.add(subTask);
                    subTask.fork();
                }
                for (CountTask t : subTasks) {
                    sum += t.join();
                }
            }
            return sum;
        }
    }

    public static void main(String[] args) throws Exception {
        ForkJoinPool forkJoinPool = new ForkJoinPool();
        ForkJoinTask<Long> task = forkJoinPool.submit(new CountTask(0, 200000L));
        try {
            long result = task.get();
            System.out.println("sum=" + result);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

// 输出:
// sum=20000100000
  1. 系统内的线程数量越积越多,导致性能严重下降。
  2. 函数的调用层次变得很深,最终导致栈溢出。

end

上一篇 下一篇

猜你喜欢

热点阅读