1 Star 14 Fork 2

Albert.Yang/concurrent-practice

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
CountTask_14.java 2.24 KB
一键复制 编辑 原始数据 按行查看 历史
Albert.Yang 提交于 2021-01-28 00:29 +08:00 . # 提交lock的内容编写
package com.albert.concurrent.book.chapterthree;
import java.util.ArrayList;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ForkJoinPool;
import java.util.concurrent.ForkJoinTask;
import java.util.concurrent.RecursiveTask;
/**
* Fork/Join框架的练习
* 分而治之
*
* @author Albert
* @date 2021/1/18 下午5:13
*/
public class CountTask_14 extends RecursiveTask<Long> {
private static final int THRESHOLD = 10000;
private long start;
private long end;
public CountTask_14(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_14> subTasks = new ArrayList<>();
long pos = start;
for (int i = 0; i < 100; i++) {
long lastOne = pos + step;
if (lastOne > end) {
lastOne = end;
}
CountTask_14 countTask = new CountTask_14(pos, lastOne);
pos += step + 1;
subTasks.add(countTask);
//线程提交执行
countTask.fork();
}
for (CountTask_14 subTask : subTasks) {
//等待线程执行完毕,并获取返回结果
sum += subTask.join();
}
}
return sum;
}
public static void main(String[] args) {
ForkJoinPool forkJoinPool = new ForkJoinPool();
CountTask_14 countTask = new CountTask_14(0, 200000L);
//使用分治提交线程
ForkJoinTask<Long> result = forkJoinPool.submit(countTask);
try {
//获取返回结果
Long res = result.get();
System.out.println("sum = "+res);
} catch (InterruptedException | ExecutionException e) {
e.printStackTrace();
}
}
}
/**
* ForkJoinTask有两个子类。
* RecursiveTask是有返回值的,RecursiveAction是没有返回值的。
*/
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Java
1
https://gitee.com/zztiyjw/concurrent-practice.git
git@gitee.com:zztiyjw/concurrent-practice.git
zztiyjw
concurrent-practice
concurrent-practice
master

搜索帮助