java.util.concurrent包下的Fork/Join框架

本文介绍了Java 1.7中的Fork/Join框架,用于解决可分解的问题。内容涵盖Fork/Join的基本概念,包括ForkJoinPool、RecursiveAction和RecursiveTask。还讨论了如何创建Fork/join池,如何处理任务结果,异步运行任务,异常处理以及如何取消任务。文章通过实例展示了Fork/Join在处理任务分解和并行计算中的应用。
摘要由CSDN通过智能技术生成

Fork/Join是JDK1.7的新特性。这个框架被设计用来解决可以使用分而治之技术将任务分解成更小的问题。

1.概念介绍

参考链接:http://ifeve.com/fork-join-1/

1)fork和join如何理解呢?
fork就是创建分支的意思:如果任务大小小于我们能接受的大小,那线程直接执行;否则,我们会创建分支,由两个子线程来执行原任务,依次递归;
join就是线程等待的意思:父任务线程创建了子任务线程,他需要等待子任务线程执行完毕,返回最终结果。

2)主要的几个类:

ForkJoinPool:执行ForkJoin的线程池,实现了ExecutorService接口;
ForkJoinTask:抽象类,是ForkJoinPool池的任务基类。其有两个实现的子类:
RecursiveAction:针对没有返回结果的子任务集;
RecursiveTask:针对有返回结果的子任务集。

2.创建一个Fork/join池

参考链接:http://ifeve.com/fork-join-2/

3)Fork/join代码:在RecursiveAction中实现compute()方法,方法中的逻辑如下:
If (problem size < default size){
execute(tasks);
} else {
tasks=divide(task);
//一般会用invokeAll(task1,task2..)
}
Recursi

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值