ForkJoin的使用

2024-02-10 12:32
文章标签 使用 forkjoin

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

可以先简单了解下【JDK中的ForkJoin机制】。

1、使用ForkJoin来实现数组中元素排序,使用invoke方法和submit方法。

package com.su.mybatis.oracle.controller;import java.util.Arrays;
import java.util.Random;
//import java.util.concurrent.ExecutionException;
import java.util.concurrent.ForkJoinPool;
//import java.util.concurrent.ForkJoinTask;
import java.util.concurrent.RecursiveTask;import com.alibaba.fastjson.JSON;public class Test {public static void main(String[] args) {long startTime = System.currentTimeMillis();ForkJoinPool pool = new ForkJoinPool();int[] array = produceArray(100);System.out.println("排序前:" + JSON.toJSONString(array));SortTask task = new SortTask(array);//1、使用invoke方法(同步)int[] result = pool.invoke(task);System.out.println("排序后:" + JSON.toJSONString(result));
//        //2、使用submit方法(异步)
//        ForkJoinTask<int[]> result = pool.submit(task);
//        try {
//            System.out.println("排序后:" + JSON.toJSONString(result.get()));
//        } catch (InterruptedException e) {
//            e.printStackTrace();
//        } catch (ExecutionException e) {
//            e.printStackTrace();
//        }System.out.println("花费时间:" + (System.currentTimeMillis()- startTime) + "ms");}static class SortTask extends RecursiveTask<int[]> {private static final long serialVersionUID = -2039880513818337443L;private final int LIMIT = 2;private int[] array;public SortTask(int[] array) {this.array = array;}@Overrideprotected int[] compute() {if(array.length <= LIMIT){//插入排序return insertionSort(array);}else{//归并排序int mid = array.length / 2;SortTask leftTask = new SortTask(Arrays.copyOfRange(array, 0, mid));SortTask rightTask = new SortTask(Arrays.copyOfRange(array, mid, array.length));invokeAll(leftTask,rightTask);int[] leftResult = leftTask.join();int[] rightResult = rightTask.join();return merge(leftResult,rightResult);}}}//生成随机数组public static int[] produceArray(int arrayLength) {Random r = new Random();int[] array = new int[arrayLength];for(int i=0;i<arrayLength;i++){array[i] =  r.nextInt(arrayLength*arrayLength);}return array;}/** 两个数组合并成一个数组,升序排列 */public static int[] merge(int[] left, int[] right) {int[] result = new int[left.length + right.length];for (int index = 0, i = 0, j = 0; index < result.length; index++) {if (i >= left.length)result[index] = right[j++];else if (j >= right.length)result[index] = left[i++];else if (left[i] > right[j])result[index] = right[j++];elseresult[index] = left[i++];}return result;}/** 插入排序 */public static int[] insertionSort(int[] array) {if (array.length == 0)return array;int currentValue;for (int i = 0; i < array.length - 1; i++) {int preIndex = i;currentValue = array[preIndex + 1];while (preIndex >= 0 && currentValue < array[preIndex]) {array[preIndex + 1] = array[preIndex];preIndex--;}array[preIndex + 1] = currentValue;}return array;}
}

使用invoke方法,输出结果:

排序前:[4310,1357,7626,506,1766,1430,8181,4019,6694,4816,445,962,6648,5475,7002,6318,2765,6712,6553,3651,2939,4180,6427,4941,2380,846,265,6194,661,769,5090,687,7633,2780,868,8475,5706,1751,1778,280,4356,6881,4040,4391,9366,6116,1080,3035,533,6938,495,9190,8879,5353,858,4624,4081,3945,5119,7223,966,9319,4569,5328,9420,7010,6899,3034,9636,2578,4480,9699,5494,4456,7893,7989,2463,3969,9204,5656,1912,5972,8246,459,4740,2987,6931,7741,9429,974,6913,2150,5596,1338,183,787,9067,6945,765,925]
排序后:[183,265,280,445,459,495,506,533,661,687,765,769,787,846,858,868,925,962,966,974,1080,1338,1357,1430,1751,1766,1778,1912,2150,2380,2463,2578,2765,2780,2939,2987,3034,3035,3651,3945,3969,4019,4040,4081,4180,4310,4356,4391,4456,4480,4569,4624,4740,4816,4941,5090,5119,5328,5353,5475,5494,5596,5656,5706,5972,6116,6194,6318,6427,6553,6648,6694,6712,6881,6899,6913,6931,6938,6945,7002,7010,7223,7626,7633,7741,7893,7989,8181,8246,8475,8879,9067,9190,9204,9319,9366,9420,9429,9636,9699]
花费时间:142ms

使用submit方法,输出结果:

排序前:[4788,5561,3948,2328,6607,6488,7901,7459,8016,9959,2340,7412,7571,4884,919,5636,4525,2477,5363,7187,9488,9975,7424,1557,8829,7998,5775,5691,8884,3433,5567,8473,8696,5353,3215,5097,5326,2302,4191,2924,8595,5654,2783,5416,429,35,7385,1426,6138,56,4970,5513,917,9216,1835,4749,1623,6330,4030,8618,793,4869,468,6885,7880,2420,2491,7457,1825,3470,8453,6142,6892,8838,7636,832,8214,7041,961,3975,3014,7049,1307,5648,6769,6045,1405,7943,6744,4530,8744,4855,5135,939,3360,2416,5769,2720,2179,8052]
排序后:[35,56,429,468,793,832,917,919,939,961,1307,1405,1426,1557,1623,1825,1835,2179,2302,2328,2340,2416,2420,2477,2491,2720,2783,2924,3014,3215,3360,3433,3470,3948,3975,4030,4191,4525,4530,4749,4788,4855,4869,4884,4970,5097,5135,5326,5353,5363,5416,5513,5561,5567,5636,5648,5654,5691,5769,5775,6045,6138,6142,6330,6488,6607,6744,6769,6885,6892,7041,7049,7187,7385,7412,7424,7457,7459,7571,7636,7880,7901,7943,7998,8016,8052,8214,8453,8473,8595,8618,8696,8744,8829,8838,8884,9216,9488,9959,9975]
花费时间:137ms

2、查找电脑指定路径下所有以“.txt"结尾的文件,使用execute方法。

package com.su.mybatis.oracle.controller;import java.io.File;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.ForkJoinPool;
import java.util.concurrent.RecursiveAction;public class Test {public static void main(String[] args) {System.out.println("main 开始执行...");ForkJoinPool pool = new ForkJoinPool();SelectFilesTask task = new SelectFilesTask(new File("D:/360MoveData/"));pool.execute(task);System.out.println("main 正在执行...");try {Thread.sleep(100);} catch (InterruptedException e) {e.printStackTrace();}task.join();//插队,等待task完成System.out.println("main 结束...");}static class SelectFilesTask extends RecursiveAction {private static final long serialVersionUID = -2039880513818337443L;private File file;public SelectFilesTask(File file) {this.file = file;}@Overrideprotected void compute() {List<SelectFilesTask> tasks = new ArrayList<>();File[] files = file.listFiles();if (files!=null){for (File file : files) {if (file.isDirectory()) {//如果文件是子目录,对子目录都新建一个任务tasks.add(new SelectFilesTask(file));} else {//不是目录,判断是否是.txt结尾if (file.getAbsolutePath().endsWith(".txt")){System.out.println("文件:" + file.getAbsolutePath());}}}if (!tasks.isEmpty()) {// 在当前的 ForkJoinPool 上调度所有的子任务。for (SelectFilesTask subTask : invokeAll(tasks)) {subTask.join();}}}}}
}

输出结果:

main 开始执行...
main 正在执行...
文件:D:\360MoveData\Users\gx\Documents\sql修改.txt
文件:D:\360MoveData\Users\gx\Desktop\aaa.txt
文件:D:\360MoveData\Users\gx\Documents\修改.txt
文件:D:\360MoveData\Users\gx\Desktop\c.txt
文件:D:\360MoveData\Users\gx\Documents\草稿.txt
文件:D:\360MoveData\Users\gx\Desktop\docker命令.txt
.
.
.
文件:D:\360MoveData\Users\gx\Documents\Navicat\MySQL\logs\LogHistory.txt
文件:D:\360MoveData\Users\gx\Desktop\安装maven环境.txt
文件:D:\360MoveData\Users\gx\Desktop\电影.txt
文件:D:\360MoveData\Users\gx\Desktop\线上.txt
文件:D:\360MoveData\Users\gx\Documents\Navicat\Premium\logs\LogHistory.txt
文件:D:\360MoveData\Users\gx\Documents\NetSarang\Xshell 5 Update Log.txt
文件:D:\360MoveData\Users\gx\Desktop\jd-gui\readme.txt
文件:D:\360MoveData\Users\gx\Desktop\jd-gui\新建文本文档.txt
main 结束...

 

 

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

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



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

相关文章

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

使用Nginx来共享文件的详细教程

《使用Nginx来共享文件的详细教程》有时我们想共享电脑上的某些文件,一个比较方便的做法是,开一个HTTP服务,指向文件所在的目录,这次我们用nginx来实现这个需求,本文将通过代码示例一步步教你使用... 在本教程中,我们将向您展示如何使用开源 Web 服务器 Nginx 设置文件共享服务器步骤 0 —

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者

Golang使用minio替代文件系统的实战教程

《Golang使用minio替代文件系统的实战教程》本文讨论项目开发中直接文件系统的限制或不足,接着介绍Minio对象存储的优势,同时给出Golang的实际示例代码,包括初始化客户端、读取minio对... 目录文件系统 vs Minio文件系统不足:对象存储:miniogolang连接Minio配置Min