第12章 分支合并框架
把复杂任务拆分成多个子任务,最终把子任务结果再做一个合并
package JUC.forkJoin; 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 VALUE = 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) <= VALUE) { //相加操作 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+1,end); task01.fork(); task02.fork(); //合并结果 result = task01.join() + task02.join(); } return result; } } public class FrokJoinDemo { 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 result = forkJoinTask.get(); System.out.println(result); //关闭池对象 forkJoinPool.shutdown(); } }
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· 没有源码,如何修改代码逻辑?
· NetPad:一个.NET开源、跨平台的C#编辑器