java Fork/Join框架的使用方法
发表于:2025-02-21 作者:千家信息网编辑
千家信息网最后更新 2025年02月21日,本篇内容介绍了"java Fork/Join框架的使用方法"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所
千家信息网最后更新 2025年02月21日java Fork/Join框架的使用方法
本篇内容介绍了"java Fork/Join框架的使用方法"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
Fork/Join框架重点说明:
1,在必要的情况下,将一个大任务,进行拆分(fork) 成若干个子任务(拆到不能再拆,这里就是指我们制定的拆分的临界值),再将一个个小任务的结果进行join汇总。
2,Fork/Join采用"工作窃取模式"。
3,ForkJoin更有效的利用的CPU资源。
4,Java 8 中将并行流进行了优化,Stream API可以声明性的通过parallel()与sequential()在并行流与串行流中随意切换。
以下是简单示例:
public class ForkJoinWorkTest extends RecursiveTask{ private Long start; private Long end; public static final Long critical = 100000L; public ForkJoinWorkTest(Long start, Long end) { this.start = start; this.end = end; } @Override protected Long compute() { Long length = end - start; if(length <= critical) { // 拆分完毕 Long sum = 0L; for(Long i = start; i <= end; i++) { sum += i; } return sum; } else { // 未拆分完毕 Long middle = (end + start)/2; ForkJoinWorkTest right = new ForkJoinWorkTest(start, middle); right.fork(); ForkJoinWorkTest left = new ForkJoinWorkTest(middle + 1, end); left.fork(); return right.join() + left.join(); } }}
单元测试代码:
import java.util.concurrent.*;import java.util.stream.LongStream;public class ForkJoinWorkTestDemo { public static void main(String args[]) { Long startTime = System.currentTimeMillis(); ForkJoinPool forkJoinPool = new ForkJoinPool(); ForkJoinTaskforkJoinTask = new ForkJoinWorkTest(0L,100000000L); Long invoke = forkJoinPool.invoke(forkJoinTask); Long endTime = System.currentTimeMillis(); System.out.println("forkAndJoin:"+invoke+" time:"+(endTime - startTime)); System.out.println("======================================================="); Long startTime1 = System.currentTimeMillis(); Long sum = 0L; for(Long i=0L;i<=100000000L;i++) { sum += i; } Long endTime1 = System.currentTimeMillis(); System.out.println("normalSum:"+sum+" time:"+(endTime1 - startTime1)); System.out.println("======================================================="); Long startTime2 = System.currentTimeMillis(); Long sum8 = LongStream.rangeClosed(0, 100000000L).parallel().reduce(0,Long::sum); Long endTime2 = System.currentTimeMillis(); System.out.println("Jdk8Sum:"+sum8+" time:"+(endTime2 - startTime2)); }}
结果如下:
"java Fork/Join框架的使用方法"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
框架
任务
使用方法
方法
内容
情况
更多
知识
结果
实用
有效
必要
学有所成
接下来
个子
中将
临界值
代码
单元
困境
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
车机网络安全
怎么判断文本框输入数据库
邮政银行软件开发工资待遇
戴尔服务器支持ddr4吗
湛江分布式服务器咨询
图片的数据库应该包含
梦幻西游限时服务器扣点不扣
天津服务器带电清洗云空间
水果 数据库
怎么测试服务器防御
口袋觉醒数据库
九江公文机器人rpa软件开发
杭州网络技术支持服务
武警计算机网络技术士官岗位
西安电子科技大学eda软件开发
数据库ora报错
软件开发2000的笔记本
网络工程互联网络技术实验报告
信息系统数据库设计原则
思科网网络安全答案
hash散列表网络安全
计算机网络技术为什么不能报二建
3DMine怎么导入数据库
匡尚互联网科技有限公司
中小型软件开发
网络安全等保服务
浦东新区辅助软件开发报价方案
网络安全实训总结心得
网吧服务器维护费用
山东临沂游戏软件开发公司