`

fork/join

 
阅读更多

fork/join

核心类

ForkJoinTask 任务的抽象类

ForkJoinWorkerThread 执行任务的线程

ForkJoinPool 执行任务队列的池

 

RecursiveTask继承了ForkJoinTask是一个带有返回的任务类

RecursiveAction不带返回的任务类

 

这里实现一个计算1-100的求和,不用高斯数列,利用任务拆解



 

新建一个SumForkJoinTask并继承RecurisiveTask任务类

重写compute方法,该方法判定是否需要二次拆解任务,如果需要,再次拆解

 



 

ForkJoinPool提交任务方法submit



 由于第一次进入的当前线程肯定不是ForkJoinWorkerThread,所以会走到addSubmission方法



 该方法将任务进队列,如果队列满了进行扩容growSubmissionQueue,在进入队列完毕后,唤醒工作线程signalWork,该方法里面的addWorker


 他和线程池的新增线程很类似,将自己作为ForkJoinWokerThread参数传入进去,并且最后启动该线程,线程run方法



 直接执行pool的work方法,work方法中,有一个不断的去循环获取队列中的任务,如果本队列任务执行完了,可以去窃取其他队列的任务,看一下他的执行任务方法



 thread的execTask方法

 一个循环,直到队列顶和最基本队列数一样,退出循环,最重要的是forkjoin的doExec方法,执行具体任务



 到这里,才算进入具体的任务方法,并在任务执行完毕后,调用setCompletion唤醒其他线程来执行任务

 

exec方法跟踪进去的时候,就可以到具体到底是使用RecursiveTask还是RecursiveAction的子任务类了,随便选择一个,进入exec方法,看到exec方法中最后调用自己的compute方法,这个方法会进入对应的我们自己实现的任务方法中,该方法根据具体的业务,会拆解二级任务,对应fork方法,该方法直接将任务塞进队列,并唤醒signalWork


 首先判定是workerThread,然后判定当前任务是否是队列中的第一个任务,如果是,则执行,执行完退出,如果不是,则执行joinTask方法


 该方法使用tryDeqAndExec来扫描工作组中所有任务,如果有工作线程队列底部正好是当前任务,则执行



 

 

 

 

 

 

 

 

  • 大小: 61 KB
  • 大小: 17.4 KB
  • 大小: 31.7 KB
  • 大小: 37.4 KB
  • 大小: 56.5 KB
  • 大小: 14.6 KB
  • 大小: 43.4 KB
  • 大小: 24.3 KB
  • 大小: 23.2 KB
  • 大小: 36.7 KB
  • 大小: 63.8 KB
  • 大小: 65.2 KB
分享到:
评论

相关推荐

    Fork/Join例子

    在Java编程领域,Fork/Join框架是一种并行计算模型,设计用于高效处理大量数据,尤其是在多核处理器系统上。这个框架是Java 7引入的一个重要特性,它基于分而治之(Divide and Conquer)策略,将复杂任务拆分为更小...

    fork/join 实例

    Fork/Join框架是Java并发处理的一个重要工具,它基于工作窃取算法,设计用于高效地执行并行计算任务。这个框架是Java 7引入的,位于`java.util.concurrent.fork/join`包中,目的是简化多核处理器环境下大规模数据...

    java Fork Join框架及使用

    Fork/Join框架是Java7引入的一种用于并行任务执行的框架,它允许将复杂任务拆分成多个子任务,并行执行,然后通过join操作将结果聚合。Fork/Join框架特别适合处理可以递归拆分的计算密集型任务,比如大数据集的搜索...

    java NIO用法及java fork/join 用法源码工程

    结合这两个技术,你可以创建高效的并发服务器,比如一个服务器端使用NIO监听和处理来自多个客户端的连接,而每个客户端请求的处理则可以利用Fork/Join框架进行并行计算。在实际项目中,`nioSample`工程可能包含这些...

    Fork/Join框架Package jsr166y

    Fork/Join框架Package jsr166y是Java 7并行编程类的的初步版本(Preliminary versions of classes targeted for Java 7.)

    Java中的Fork/Join框架

    看了下Java Tutorials中的fork/join章节,整理下。  什么是fork/join框架  fork/join框架是ExecutorService接口的一个实现,可以帮助开发人员充分利用多核处理器的优势,编写出并行执行的程序,提高应用程序的...

    Java并发Fork and join

    Fork/Join框架是Java并发库中的一部分,自Java 7开始引入,它为开发者提供了一种高效的处理大规模计算任务的方法。这个框架基于分治策略,将大任务分解成若干小任务,然后并行执行这些小任务,最后再将结果合并。...

    Java中的Fork,Join框架深度解析

    Java的Fork/Join框架是一种用于并行计算的框架,它基于分治法的原理,将大任务分解成小任务并行执行,最后再将结果合并。这种框架特别适合于可以分解为多个子任务且子任务可以并行处理的场景。本文将详细介绍Fork/...

    Java通过Fork/Join优化并行计算

    Java的Fork/Join框架是Java 7引入的一个并行计算工具,它是基于分而治之(Divide and Conquer)策略的。该框架旨在简化并行编程,尤其是在多核处理器环境中提高性能。Fork/Join框架的核心类包括`ForkJoinPool`和`...

    浅谈Java Fork/Join并行框架

    Java Fork/Join 并行框架 Java Fork/Join 并行框架是 Java 7 中引入的一个并行任务框架,可以将任务分割成足够小的小任务,然后让不同的线程来做这些分割出来的小事情,然后完成之后再进行 join,将小任务的结果...

    译文:Fork and Join: Java Can Excel at Painless Parallel Programming Too!

    Fork/Join框架是Java SE 7引入的一项重要技术,它使得编写高效、并行的程序变得更加容易。本文将简要回顾Java中的并发编程基础知识,介绍java.util.concurrent包提供的高级并发原语,并深入探讨Fork/Join框架及其在...

    Java Fork/Join框架

    Java Fork/Join框架是Java 7引入的一种并行计算模型,设计目的是为了高效地处理大量数据,尤其是在多核处理器环境中。该框架的核心理念是通过将复杂的大任务分解为多个小任务,然后并行执行这些小任务,从而加速计算...

    Fork Join框架机制详解.docx

    Fork/Join框架基于分治策略,即将一个复杂的大任务分解成两个或更多个较小的任务,直到这些任务小到可以直接计算结果,然后将这些结果合并得到最终答案。在Java中,Fork/Join框架主要由`ForkJoinPool`线程池和`...

    Fork-Join框架演示

    ### Java Fork-Join框架详解与应用 #### 一、并发编程与Fork-Join框架的引入 在现代计算环境中,多核处理器已经成为标配,这为软件开发者提供了利用硬件并行性的巨大潜力。然而,传统的并发编程模型,如基于线程的...

    ForkJoinUtil.java,一个分而治之的框架工具类

    Fork/Join框架的测试demo,含源代码。 Fork/Join框架是Java7提供了的一个用于并行执行任务的框架, 是一个把大任务分割成若干个小任务,最终汇总每个小任务结果后得到大任务结果的框架。 我们再通过Fork和Join这两个...

    35 拆分你的任务—学习使用Fork-Join框架.pdf

    在Java并发编程中,Fork/Join框架是一个强大的工具,尤其在处理大量数据时能显著提升性能。这个框架从Java 7开始引入,是ExecutorService的一个实现,它基于分而治之的策略,将大任务分解成多个小任务,然后并行地...

    JDK7中的ForkJoin模式

    JDK 7 中引入的 Fork/Join 模式是一种基于分治策略的并行编程模型,旨在简化在多核处理器环境下实现高效的并行计算。这一模式的核心思想是将复杂的大任务拆分成一系列小任务,然后将这些小任务并行执行,最后再合并...

    Fork:join框架与CompleteableFuture源码解析.pptx

    全网第一篇通过图文介绍Fork/Join框架与CompleteableFuture的PPT

    java fork-join框架介绍

    fork/join框架是ExecutorService接口的一个实现,可以帮助开发人员充分利用多核处理器的优势,编写出并行执行的程序,提高应用程序的性能;设计的目的是为了处理那些可以被递归拆分的任务。

Global site tag (gtag.js) - Google Analytics