fork/join框架

news2025/1/23 9:15:36

文章目录

  • 前言
  • 一、fork/join是什么?
  • 二、使用步骤
  • 总结


前言

使用Fork/Join框架首先要考虑到的是如何分割任务,分割之后,根据join 再进行任务结果的合并,也就是类似二分法的,分而治之的理念;


一、fork/join是什么?

  • fork 拆分任务,将大任务拆分成小任务,拆的有多小呢? 这个可以根据自己的情况而定
  • join 合并拆分的结果, 无论如何拆分,最终的计算结果应该是对的

二、使用步骤

废话不多说,直接上代码

public class ForkJoin使用 extends RecursiveTask<Integer> {

    private static int yuzhi = 10;
    private Integer start;
    private Integer end;


    public ForkJoin使用(Integer start, Integer end) {
        this.start = start;
        this.end = end;
    }

    @Override
    protected Integer compute() {
        Integer res = 0;

        if ((end - start) <= 10) {
            for (Integer i = start; i <= end; i++) {
                res += i;
            }
        } else {

            Integer middle = (start + end) / 2;
            ForkJoin使用 forkJoin使用 = new ForkJoin使用(start, middle);
            ForkJoin使用 forkJoin使用1 = new ForkJoin使用(middle + 1, end);

            ForkJoinTask<Integer> fork = forkJoin使用.fork();
            ForkJoinTask<Integer> fork1 = forkJoin使用1.fork();
            try {
                res = fork.get() + fork1.get();
            } catch (InterruptedException e) {
                throw new RuntimeException(e);
            } catch (ExecutionException e) {
                throw new RuntimeException(e);
            }
        }

        return res;
    }


    @SneakyThrows
    public static void main(String[] args) {

        ForkJoinPool forkJoinPool = new ForkJoinPool();

        ForkJoin使用 forkJoin = new ForkJoin使用(1, 100);

        ForkJoinTask<Integer> submit = forkJoinPool.submit(forkJoin);

        Integer integer = submit.get();

        System.out.println(integer);

    }
}
  • 我的最大任务是计算 1 -100 的和
  • fork拆分: 我想每个最小子任务执行10的数的相加,这就是具体拆分的情况
  • join 我利用join 得到每个子任务的执行的结果
  • 整体是一个递归执行
  • (end - start) <= 10 每次递归通过此判断是否应该继续拆分子任务
  • 不满足上述条件,继续拆分,满足直接计算
  • ForkJoinPool 通过这个框架执行我们的最大任务
  • RecursiveTask 继承它,然后重写compute 这就是这个递归的核心逻辑了

计算结果


总结

fork join 框架的思想就是通过分而治之的理念,去处理大量数据; 核心是利用递归处理,底层也是通过多线程实现;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/570471.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux学习笔记---编辑器Vim

Vim是Linux中功能十分强大的文本编辑器&#xff0c;熟练地使用Vim可以让你高效地在Shell界面编写代码&#xff0c;接下来我们开始一步一步地学习Vim的使用方法: 一、文本编辑器vim的使用 1. 打开Vim 打开终端直接输入vim&#xff0c;即可打开Vim编辑器主界面 它是原始vi编辑…

简单谈谈BIO,NIO,AIO

目录 IO 概述 阻塞 IO (BIO) 基本理解 非阻塞 IO(NIO) ​核心部分 Channel Buffer Selector Channel Buffer Selector 三者关系 异步非阻塞 IO(AIO) IO 概述 IO 的操作方式通常分为几种&#xff1a;同步阻塞 BIO、同步非阻塞 NIO、异步非阻塞 AIO。 &#xff08;1…

如何检查Linux硬盘大小、类型和硬件详细信息?

在Linux系统中&#xff0c;了解硬盘的大小、类型和硬件详细信息对于系统管理和故障排除非常重要。本文将详细介绍如何使用命令行工具来检查Linux硬盘的大小、类型和硬件详细信息。 1. 检查硬盘大小 要检查Linux硬盘的大小&#xff0c;可以使用lsblk命令。该命令显示了系统中所…

chatgpt赋能python:Python取位:介绍和应用

Python取位&#xff1a;介绍和应用 Python是一种解释型&#xff0c;高级&#xff0c;通用编程语言。它在最近几年中变得越来越受欢迎&#xff0c;因为它易于学习和使用&#xff0c;并且具有很强的可读性和简洁性。在Python编程中&#xff0c;取位是一种很常见的操作。在本文中…

chatgpt赋能python:Python中如何取空格之前的内容?

Python中如何取空格之前的内容&#xff1f; 在Python中&#xff0c;我们经常需要从文本中提取关键信息&#xff0c;但有时这些信息的位置并不是固定的&#xff0c;而是被包围在一些无用的字符中&#xff0c;比如空格。那么&#xff0c;在Python中&#xff0c;如何取空格之前的…

springboot医院在线医疗挂号服务系统+jsp网上药店药品商城b254v

选题意义、价值和目标&#xff1a; 随着经济的迅速发展,人们对生活水平和身体健康的要求越来越高,但同时也面临着优质医疗资源紧缺,看病难,看病贵,医患关系危机等各种各样的问题。近些年,越来越多传统行业的服务被迁移到互联网上来。如何使用互联网技术解决当前医疗系统中存在的…

用R语言绘制三维曲面

文章目录 graphics::persplattice::wireframergl::plot3drgl::surface3dscatterplot3d::scatterplot3d graphics::persp x <- seq(-10, 10, length.out 30) y <- x f <- function(x, y) { r <- sqrt(x^2y^2); 10 * sin(r)/r } z <- outer(x, y, f) z[is.na(z)…

chatgpt赋能python:Python中如何去除NaN?-一个有10年python编程经验的工程师

Python中如何去除NaN&#xff1f; - 一个有10年python编程经验的工程师 NaN即Not a Number的缩写&#xff0c;表示非数字&#xff0c;也称为缺失值。在数据分析和机器学习中&#xff0c;经常会遇到数据集中存在NaN的情况。 Python提供了许多实用的库和函数&#xff0c;可以轻…

chatgpt赋能python:Python去掉空格和换行——提升网站的SEO排名

Python去掉空格和换行——提升网站的SEO排名 空格和换行是我们日常生活和编程中经常遇到的问题&#xff0c;特别是在网站开发中&#xff0c;它们会大大影响网站的SEO排名。因此&#xff0c;在这篇文章中&#xff0c;我们将介绍如何使用Python去掉空格和换行&#xff0c;以提升…

linux信号量与PV操作知识点总结

信号量 信号量(semaphore) 与已经介绍过的 IPC 结构不同&#xff0c;它是一个计数器&#xff0c;信号量用于实现进程间的与斥与同步&#xff0c;而不是用于存储进程间通信数据。 1、特点 &#xff08;1&#xff09;信号量用于进程间同步&#xff0c;若要在进程间传递数据需要结…

如何在华为OD机试中获得满分?Java实现【优秀学员统计】一文详解!

✅创作者&#xff1a;陈书予 &#x1f389;个人主页&#xff1a;陈书予的个人主页 &#x1f341;陈书予的个人社区&#xff0c;欢迎你的加入: 陈书予的社区 &#x1f31f;专栏地址: Java华为OD机试真题&#xff08;2022&2023) 文章目录 1. 题目描述2. 输入描述3. 输出描述…

C++是如何从代码到游戏的

有一个Student类。C怎么创建一个学生类的对象&#xff1f; // 嗯我会&#xff01;有两种方式&#xff1a; Student s; Student *s2 new Student("张三");现在这学生的行为有&#xff1a;吃饭&#xff0c;睡觉&#xff0c;上网课。现在你执行个上网课的行为&#xf…

chatgpt赋能python:Python取数简介

Python取数简介 Python是一款强大的编程语言&#xff0c;可以轻松地处理各种数据类型并进行数据分析。Python的强大功能也使其成为数据科学和机器学习等领域非常受欢迎的编程语言。在这篇文章中&#xff0c;我们将探讨在Python中如何取数。 Python中的取数 Python中有多种方…

C#,码海拾贝(24)——线性方程组求解的复系数方程组的全选主元高斯-约当消去法之C#源代码,《C#数值计算算法编程》源代码升级改进版

using System; namespace Zhou.CSharp.Algorithm { /// <summary> /// 求解线性方程组的类 LEquations /// 原作 周长发 /// 改编 深度混淆 /// </summary> public static partial class LEquations { /// <summary> …

delphi11.3的WebBrower支持Edge

看到此消息后&#xff0c;立即下载了DelphiCE&#xff08;社区版&#xff09; 安装&#xff0c;创建项目&#xff0c;放TWebBrowers&#xff0c;TButton 配置参数为EdgeOnly F9运行&#xff0c;没反应 配置参数为EdgeIfAvailable F9运行&#xff0c;提示浏览器版本过低 全网搜索…

chatgpt赋能python:Python取两者之间的最大值

Python取两者之间的最大值 介绍 Python是一种高级编程语言&#xff0c;广泛应用于计算机科学、人工智能、数据科学、机器学习等不同领域。它的易用性和灵活性使它成为许多开发人员首选的工具。本篇文章将介绍如何使用Python来取两者之间的最大值。 如何取两者之间的最大值 …

URP自定义屏幕后处理

回到目录 大家好&#xff0c;我是阿赵。这次来说一下URP渲染管线里面怎样使用后处理效果&#xff0c;还有怎样去自定义后处理效果。 一、使用URP自带的后处理效果 要使用URP自带的后处理效果&#xff0c;方法很简单&#xff0c;和Unity内置渲染管线的PostProcessing后处理很…

如何在Linux中更改SSH端口?

SSH&#xff08;Secure Shell&#xff09;是一种安全的远程登录协议&#xff0c;它允许您通过网络远程连接到Linux系统并进行管理操作。默认情况下&#xff0c;SSH使用22端口进行通信。然而&#xff0c;为了增强系统的安全性&#xff0c;有时候我们需要更改SSH端口&#xff0c;…

chatgpt赋能python:Python分解——探究Python语言的精髓

Python分解——探究Python语言的精髓 Python作为一种动态解释性语言&#xff0c;逐渐成为数据科学和人工智能领域的“标配”。Python语言的优势不仅在于其简洁而直观的语法&#xff0c;更在于其开源庞大的生态系统。而Python分解&#xff0c;则是将Python语言的优势、拆分并深…

chatgpt赋能python:Python内连接的重要性

Python内连接的重要性 在数据分析和机器学习领域&#xff0c;内连接是一种非常重要的概念&#xff0c;用于筛选和分析不同数据集之间的共同项。Python语言的强大功能和广泛的库可以帮助我们轻松地实现内连接。在本文中&#xff0c;我们将介绍Python内连接的基础知识、实现方式…