Java7中的ForkJoin并发框架初探(上)——需求背景和设计原理
来源:互联网 发布:actor模型 知乎 编辑:程序博客网 时间:2024/06/07 23:06
引用于:http://www.molotang.com/articles/694.html
最近事情较多,好久没发文章了。前面关于Java并发的文章中主要介绍了并发的概念、思想、JavaSE5中java.util.concurrent包中的工具类的使用和实现源码的分析。这篇我们来简要了解一下JavaSE7中提供的一个新特性 —— Fork Join 框架。
0. 处理器发展和需求背景
回想一下并发开发的初衷,其实可以说是有两点,或者说可以从两个方面看。
- 对于单核的处理器来说,在进行IO操作等比较费时的操作进行时,如果执行任务的方式是单任务的,那么CPU将会“空转”,知道IO操作结束。如果有多任务的调度机制,则在一个任务不需要CPU支持的时候,CPU可以被调度处理其他任务。简单地讲,并发可以提高CPU计算资源的利用率。
- 对于多核,或者多个计算资源的情况下,并发可以在某种程度上达到“并行”,即同时运行,缩短了任务完成的时间,提高了任务完成的效率。
我们再来看一下处理器计算能力的发展(讲并发或者并行基本都要提到),Intel的创始人之一Gordon Moore曾经说过一句话,大概意思是:
当价格不变时,集成电路上可容纳的晶体管数目,约每隔18个月便会增加一倍,性能也将提升一倍。
我们可以这样理解,处理器的计算能力在一定意义上和芯片上集成的晶体管数量有关,而这项继承技术的发展史飞快的。但是,什么事情都是有一个极限的,提升计算性能仅仅靠增加晶体管数量提高处理器主频是不现实的,于是多核处理器的概念就出来了。
随着在硬件上多核处理器的发展和广泛使用,软件开发上的变革也在进行。简单来想,对于多个不相关的小任务来讲,可以分派到不同的处理器核心来进行处理。然而,对于一个比较大的任务,如何能够充分利用多核计算资源就是一个值得考虑的问题。
解决这个问题的办法就是“分而治之”,而Fork Join正式这样一种思路的产物。
1. Fork Join 的设计简介
看过《Introduction to Algorithms》(《算法导论》)的朋友们应该还记得,在讲到归并排序(Merge Sort)和快速排序的时候,有一种很简单又很有效率的思路就是“分而治之”,即“分治法”。而Fork Join的思路也是同理,只不过划分之后的任务更适合分派给不同的计算资源,可以并行的完成任务。
当计算分别完成之后,最后再合并回来。
简单来看,就是一个递归的分解和合并,直到任务小到可以接受的程度。
2. Fork Join 设计要点
Fork Join设计出来就是为了提高任务完成的效率,围绕这个目标,有一些要点是设计中需要考虑的,下面就给出一些要点。
- 线程的管理和线程的单纯性。基于如上的设计思路,我们可以看到子任务之间的相关性是相对比较简单的,可以并行处理。为了提高效率,并不需要重量级的线程结构和对应的线程维护,线程实现简单就好,满足需求即可,降低维护成本。
- 队列机制,硬件支持一定是比较有限的,那么分解的任务应该用队列维护起来,一个好的队列设计是很有必要的。
- “工作窃取”,也就是设计论文原文中提到的 Work Stealing 。对于负载比较轻的线程,可以帮助负载较重的执行线程分担任务。
对于使用Fork Join的开发者来讲,需要注意:
- 可用线程数和硬件支持。线程这东西,也是有开销的东西,绝对不是越多越好,尤其在硬件基础有限的情况下。
- 任务分解的粒度。和前者有关系,就是分解的任务,“小”到什么程度是可以接受的,不可再分。
3. Fork Join数据结构支持
按照如上设计,分解执行一个大的任务,Fork Join至少需要考虑如下一些数据结构。
- 轻量级的线程结构。
- 维护线程的线程池,负责线程的创建,数量维护和任务管理。
- 维护任务,并支持Work Stealing的双端队列。如下图。
对于子任务的分解,可以从后端取出分解再放入,而对于WorkStealing则可以从头部取出,放入其他队列的尾部。
到此,本文仅仅是对Fork Join的大致设计思路做一个描述、勾勒。下一篇文章中会对JDK1.7中给出的实现作出分析。
4. Fork Join其它参考
Doug Lea的文章可参见这里:DougLea关于ForkJoin设计、实现和性能分析的文章原文
- Java7中的ForkJoin并发框架初探(上)——需求背景和设计原理
- [转]Java7中的ForkJoin并发框架初探(上)——需求背景和设计原理
- forkjoin并发框架—需求背景和设计原理
- Java7中的ForkJoin并发框架初探(下)—— ForkJoin的应用
- [转]Java7中的ForkJoin并发框架初探(下)—— ForkJoin的应用
- 学习笔记之Java7中的ForkJoin并发框架初探(下)—— ForkJoin的应用
- Java7中的ForkJoin并发框架初探(中)——JDK中实现简要分析
- [转]Java7中的ForkJoin并发框架初探(中)——JDK中实现简要分析
- Java7 ForkJoin 框架
- Java7新特性(四)并发 8 forkjoin分支合并框架
- ForkJoin并发框架—样例及实现分析
- JAVA7 的ForkJoin框架-学习笔记
- ForkJoin框架(一):ForkJoin框架概述
- java7之forkjoin实现
- Java7 ForkJoin入门实例
- Java7 ForkJoin 源码分析
- ForkJoin框架的一些原理知识点
- ForkJoin框架(二):ForkJoinTask
- CSS3 经典教程系列:CSS3 圆角(border-radius)详解
- 七周七语言——Erlang第一天自习
- sencha touch 通过.axhx获取后台数据时,Unable to parse the JSON returned by the server: Error: You're trying to
- Matlab reshape 函数
- guard常用查询命令
- Java7中的ForkJoin并发框架初探(上)——需求背景和设计原理
- OOZIE
- unity3d游戏开发之入门
- 考研党的寒假学习之spring+hibernate(1)
- 自动排队的异步Ajax请求
- Write 全选反选实现例子
- 生成动态链接库DLL但未生成lib文件的解决办法
- 兄弟连云Android学习笔记——Dialog(对话框)
- guard的体系结构