forkJoin的使用,分支合并
forkJoin的使用,分支合并
如何使用forkJoin
1、forkJoinPool 通过他来执行
2、计算任务 forkJoinPool.execute(ForkJoinTask task)
3、计算要继承forkJoinTask
package ForkJoinA;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ForkJoinPool;
import java.util.concurrent.ForkJoinTask;
import java.util.stream.LongStream;
/**分支合并 ForkJoin
* @author liu
*/
public class Test {
public static void main(String[] args) throws ExecutionException, InterruptedException {
//test1();//结果:500000000500000000 时间:4841
//test2();//500000000500000000 时间:7876
test3();
}
public static void test1() {
Long sum = 0L;
long start = System.currentTimeMillis();
for (int i = 1; i <= 10_0000_0000; i++) {
sum += i;
}
long end = System.currentTimeMillis();
System.out.println("结果:" + sum + " 时间:" + (end - start));
}
public static void test2() throws ExecutionException, InterruptedException {
long start = System.currentTimeMillis();
ForkJoinPool forkJoinPool = new ForkJoinPool();
ForkJoinTask<Long> task = new Demo01(0L, 10_0000_0000L);
ForkJoinTask<Long> submit = forkJoinPool.submit(task);//提交任务
Long sum = submit.get();
long end = System.currentTimeMillis();
System.out.println("结果:" + sum + " 时间:" + (end - start));
}
public static void test3() {
long start = System.currentTimeMillis();
//stream并行流 range并发是() rangeClose是( ] reduce减少
Long sum = LongStream.rangeClosed(0L, 10_0000_0000L).parallel().reduce(0L,Long::sum);
long end = System.currentTimeMillis();
System.out.println("结果:" + sum + " 时间:" + (end - start));
}
}
extends RecursiveTask ,重写compute
package ForkJoinA;
import java.util.concurrent.RecursiveTask;
/**
* 如何使用forkJoin
* 1、forkJoinPool 通过他来执行
* 2、计算任务 forkJoinPool.execute(ForkJoinTask task)
* 3、计算要继承forkJoinTask
*
* @author liu
*/
public class Demo01 extends RecursiveTask<Long> {
private Long start;
private Long end;
//临界值
private Long temp = 10000L;
public Demo01(Long start, Long end) {
this.start = start;
this.end = end;
}
//计算方法
@Override
protected Long compute() {
if ((end - start) < temp) {
Long sum = 0L;
for (Long i = start; i < end + 1; i++) {
sum = sum + i;
}
return sum;
} else {//forkJoin 递归
Long mid=(start+end)/2;
Demo01 task1=new Demo01(start,mid);
task1.fork();//拆分任务,把任务压入线程队列
Demo01 task2=new Demo01(mid+1,end);
task2.fork();//拆分任务,把任务压入线程队列
return task1.join()+task2.join();
}
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现