码迷,mamicode.com
首页 > 其他好文 > 详细

Fork/Join

时间:2015-04-18 14:46:05      阅读:145      评论:0      收藏:0      [点我收藏+]

标签:

import java.util.concurrent.ExecutionException;
import java.util.concurrent.ForkJoinPool;
import java.util.concurrent.ForkJoinTask;
import java.util.concurrent.RecursiveTask;

/**
 * @author Vincent Zhao
 * @version 1.0.0
 * @Time 2015/4/18 13:15
 */
public class ForkJoinDemo {

    public static void main(String[] args) throws ExecutionException, InterruptedException {
        ForkJoinPool pool = new ForkJoinPool();
        ForkJoinTask<Long> submit = pool.submit(new Calculator(0, 1000000));
        System.out.println(submit.get());
    }
}

class Calculator extends RecursiveTask<Long> {

    public static final int THRESHOLD = 100;

    private long start;

    private long end;

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

    @Override
    protected Long compute() {
        long sum = 0;
        if ((end - start) < THRESHOLD) {
            for (long i = start; i < end; i++) {
                sum += i;
            }
        } else {
            long middle = (start + end) / 2;
            Calculator left = new Calculator(start, middle);
            Calculator right = new Calculator(middle + 1, end);
            left.fork();
            right.fork();
            sum = left.join() + right.join();
        }
        return sum;
    }
}


Fork/Join

标签:

原文地址:http://my.oschina.net/u/1792430/blog/403316

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!