JDK中的ForkJoin机制

2024-02-10 12:32
文章标签 jdk 机制 forkjoin

本文主要是介绍JDK中的ForkJoin机制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ForkJoin的原理

ForkJoin的核心思想是分而治之。分而治之是指将一个大任务拆分(fork)成若干个小任务,分别计算每个小任务,得到结果,再将所有小任务的结果执行汇总(join),得到最终结果。当然,也不是说随便就能拆分的,要求小任务互相独立且与大任务形式相同。JDK为我们提供了ForkJoin机制,我们不需要考虑线程调度问题(比如:使用ForkJoinPool),也不需要考虑任务的拆分和结果的汇总(比如:使用ForkjoinTask等),只需要考虑业务实现。

过程图解

工作密取

当前线程的任务完成后,会自动获取其他线程未完成的任务进行执行,如下图中所示,假设某个大任务总共拆分成了8个任务,由两个线程执行,当线程1执行完任务1/2/3/4时,线程2才刚好开始执行任务7(或者任务5/6),这个时候线程1就会从线程2的任务队列末尾拿到任务8并执行,将执行结果放回到线程2的任务队列中,这样能够减少线程阻塞或者闲置的时间,提高CPU利用率,提高性能。

任务拆分和结果汇总

JDK中提供了专门的类完成任务拆分和结果汇总的操作。比如ForkjoinTask类,但是我们通常并不是直接继承这个类,而是直接继承其子类——RecursiveAction和RecursiveTask。RecursiveAction,用于没有返回结果的任务;RecursiveTask,用于有返回结果的任务。

ForkJoin的使用流程

1)、创建一个ForkJoinPool,用来执行任务;

2)、创建一个任务(业务逻辑),建议继承RecursiveAction和RecursiveTask,不建议继承ForkjoinTask;

3)、使用ForkJoinPool的执行方法:invoke/execute/submit,其中invoke方法是同步方法,execute/submit是异步方法,execute无返回值,submit有返回值;

4)、如果第3步中使用invoke,可以直接获得结果;如果使用execute,没有结果返回;如果使用submit,可以在方法中使用join对结果汇总,使用get方法获取结果。

 

 

如果有写的不对的地方,请大家多多批评指正,非常感谢!

这篇关于JDK中的ForkJoin机制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/697106

相关文章

SpringRetry重试机制之@Retryable注解与重试策略详解

《SpringRetry重试机制之@Retryable注解与重试策略详解》本文将详细介绍SpringRetry的重试机制,特别是@Retryable注解的使用及各种重试策略的配置,帮助开发者构建更加健... 目录引言一、SpringRetry基础知识二、启用SpringRetry三、@Retryable注解

SpringKafka错误处理(重试机制与死信队列)

《SpringKafka错误处理(重试机制与死信队列)》SpringKafka提供了全面的错误处理机制,通过灵活的重试策略和死信队列处理,下面就来介绍一下,具有一定的参考价值,感兴趣的可以了解一下... 目录引言一、Spring Kafka错误处理基础二、配置重试机制三、死信队列实现四、特定异常的处理策略五

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Linux卸载自带jdk并安装新jdk版本的图文教程

《Linux卸载自带jdk并安装新jdk版本的图文教程》在Linux系统中,有时需要卸载预装的OpenJDK并安装特定版本的JDK,例如JDK1.8,所以本文给大家详细介绍了Linux卸载自带jdk并... 目录Ⅰ、卸载自带jdkⅡ、安装新版jdkⅠ、卸载自带jdk1、输入命令查看旧jdkrpm -qa

java中反射(Reflection)机制举例详解

《java中反射(Reflection)机制举例详解》Java中的反射机制是指Java程序在运行期间可以获取到一个对象的全部信息,:本文主要介绍java中反射(Reflection)机制的相关资料... 目录一、什么是反射?二、反射的用途三、获取Class对象四、Class类型的对象使用场景1五、Class

JDK多版本共存并自由切换的操作指南(本文为JDK8和JDK17)

《JDK多版本共存并自由切换的操作指南(本文为JDK8和JDK17)》本文介绍了如何在Windows系统上配置多版本JDK(以JDK8和JDK17为例),并通过图文结合的方式给大家讲解了详细步骤,具有... 目录第一步 下载安装JDK第二步 配置环境变量第三步 切换JDK版本并验证可能遇到的问题前提:公司常

Windows系统下如何查找JDK的安装路径

《Windows系统下如何查找JDK的安装路径》:本文主要介绍Windows系统下如何查找JDK的安装路径,文中介绍了三种方法,分别是通过命令行检查、使用verbose选项查找jre目录、以及查看... 目录一、确认是否安装了JDK二、查找路径三、另外一种方式如果很久之前安装了JDK,或者在别人的电脑上,想

IDEA与JDK、Maven安装配置完整步骤解析

《IDEA与JDK、Maven安装配置完整步骤解析》:本文主要介绍如何安装和配置IDE(IntelliJIDEA),包括IDE的安装步骤、JDK的下载与配置、Maven的安装与配置,以及如何在I... 目录1. IDE安装步骤2.配置操作步骤3. JDK配置下载JDK配置JDK环境变量4. Maven配置下

Nginx之upstream被动式重试机制的实现

《Nginx之upstream被动式重试机制的实现》本文主要介绍了Nginx之upstream被动式重试机制的实现,可以通过proxy_next_upstream来自定义配置,具有一定的参考价值,感兴... 目录默认错误选择定义错误指令配置proxy_next_upstreamproxy_next_upst

Spring排序机制之接口与注解的使用方法

《Spring排序机制之接口与注解的使用方法》本文介绍了Spring中多种排序机制,包括Ordered接口、PriorityOrdered接口、@Order注解和@Priority注解,提供了详细示例... 目录一、Spring 排序的需求场景二、Spring 中的排序机制1、Ordered 接口2、Pri