juc-分支合并框架
package lock; import java.util.concurrent.ExecutionException; import java.util.concurrent.ForkJoinPool; import java.util.concurrent.ForkJoinTask; import java.util.concurrent.RecursiveTask; //分支合并 class MyTask extends RecursiveTask<Integer>{ //拆分差值不超过10 private static final Integer number = 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>=number){ //相加操作 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,end); //调用方法拆分 task01.fork(); task02.fork(); //合并结果 result = task01.join() + task02.join(); } return result; } } public class Lock_10 { public static void main(String[] args) throws ExecutionException, InterruptedException { //创建MyTask对象 MyTask myTask = new MyTask(0,100); //创建分支合并池对象 ForkJoinPool forkJoinPool = new ForkJoinPool(); ForkJoinTask<Integer> forkJoinTask = forkJoinPool.submit(myTask); //获取最终合并之后结果 Integer integer = forkJoinTask.get(); System.out.println(integer); //关闭池对象 forkJoinPool.shutdown(); } }
fork是分支
join是合并
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?