返回顶部
首页 > 资讯 > 后端开发 > Python >Java 多线程等待优雅的实现方式之Phaser同步屏障
  • 613
分享到

Java 多线程等待优雅的实现方式之Phaser同步屏障

2024-04-02 19:04:59 613人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

前言 是否会遇到这样的场景,你向线程池提交了多个任务,你希望这批任务全部完成后能够反向通知你。 你可能会使用线程计数的方式,等到计数器累加到提交的线程数量,然后通知。emmm,不是不

前言

是否会遇到这样的场景,你向线程池提交了多个任务,你希望这批任务全部完成后能够反向通知你。

你可能会使用线程计数的方式,等到计数器累加到提交的线程数量,然后通知。emmm,不是不可以,只是不够优雅。本文提供优雅的实现方式,Phaser同步屏障。

Maven依赖

也可以不依赖,本人习惯把代码简单化,使用了hutool,所以依赖只有这个。


        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.7.15</version>
        </dependency>

代码

废话不多说,上代码。


package com.huyi.csdn.tools;
 
import cn.hutool.core.thread.ThreadUtil;
 
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Phaser;
import java.util.concurrent.TimeUnit;
 

public class PhaserUtil {
  public static final ExecutorService executorService = Executors.newFixedThreadPool(50);
 
  public static class CustomPharser extends Phaser {
    private final Runnable runnable;
 
    public CustomPharser(Runnable runnable) {
      this.runnable = runnable;
    }
 
    @Override
    protected boolean onAdvance(int phase, int reGISteredParties) {
      this.runnable.run();
      return super.onAdvance(phase, registeredParties);
    }
  }
 
  
  public static void submit(List<Runnable> tasks, Runnable complete) {
    Phaser phaser = new CustomPharser(complete);
    for (Runnable runnable : tasks) {
      executorService.submit(
          () -> {
            phaser.register();
            runnable.run();
            System.out.println(Thread.currentThread().getName() + "完成任务!");
            phaser.arriveAndAwaitAdvance();
          });
    }
  }
 
  
  public static void destroy() {
    System.out.println("摧毁线程池");
    executorService.shutdown();
  }
 
  public static void main(String[] args) {
    List<Runnable> tasks = new ArrayList<>();
    Random random = new Random();
    for (int i = 0; i < 10; i++) {
      tasks.add(
          () -> {
            ThreadUtil.sleep(random.nextInt(10), TimeUnit.SECONDS);
          });
    }
    submit(tasks, () -> System.out.println("所有任务已完成"));
    ThreadUtil.sleep(20, TimeUnit.SECONDS);
    destroy();
  }
}

代码说明

1、提交任务执行的方式是Runnable也好,Callable也好,或者Consumer、Function等等,不影响,你可以看着调整。

2、完成后的Runnable也和第一点同理。

验证一下

OK,没什么问题。

总结

其实我一直想分享一些可以让读者工作中能用到的东西,想到牧神记里面的一句话,圣人之道,无非就是百姓日用。emmmm,又废话了。

分享一下:

没必要的事就不做,必要的事就尽快做。---冰果

如果本文对你有用,请不要吝啬你的赞,谢谢。

以上就是Java 多线程等待优雅的实现方式之Phaser同步屏障的详细内容,更多关于Java 多线程等待的资料请关注编程网其它相关文章!

--结束END--

本文标题: Java 多线程等待优雅的实现方式之Phaser同步屏障

本文链接: https://lsjlt.com/news/156924.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Java 多线程等待优雅的实现方式之Phaser同步屏障
    前言 是否会遇到这样的场景,你向线程池提交了多个任务,你希望这批任务全部完成后能够反向通知你。 你可能会使用线程计数的方式,等到计数器累加到提交的线程数量,然后通知。emmm,不是不...
    99+
    2024-04-02
  • Java多线程中如何实现Phaser同步屏障
    这篇文章将为大家详细讲解有关Java多线程中如何实现Phaser同步屏障,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。前言是否会遇到这样的场景,你向线程池提交了多个任务,你希望这批任务全部完...
    99+
    2023-06-25
  • Java多线程同步实现的方式是什么
    这篇文章主要讲解了“Java多线程同步实现的方式是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java多线程同步实现的方式是什么”吧!给我一把锁,我能创造一个规矩很多人都知道,在Jav...
    99+
    2023-06-17
  • Java循环屏障中CyclicBarrier如何实现多线程分段等待执行完成
    Java循环屏障中CyclicBarrier如何实现多线程分段等待执行完成,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。前言工作中是否有这样的场景,多个线程任务...
    99+
    2023-06-25
  • Java 详解循环屏障CyclicBarrier如何实现多线程分段等待执行完成
    前言 工作中是否有这样的场景,多个线程任务,如果所有线程完成到某个阶段,你希望知道所有线程均完成该阶段。当然你使用线程计数可以实现,只是不够优雅。 所以我即:Java 多线程等待优雅...
    99+
    2024-04-02
  • Python多线程实现同步的四种方式
    临界资源即那些一次只能被一个线程访问的资源,典型例子就是打印机,它一次只能被一个程序用来执行打印功能,因为不能多个线程同时操作,而访问这部分资源的代码通常称之为临界区。 锁机制 threading的Lock...
    99+
    2022-06-04
    四种 多线程 方式
  • java多线程之线程同步的方法有哪些
    Java中线程同步的方法有以下几种:1. synchronized关键字:使用synchronized关键字可以实现对代码块、方法或...
    99+
    2023-09-27
    java
  • Java实现多线程同步的方法有哪些
    Java实现多线程同步的方法有以下几种:1. 使用synchronized关键字:通过在方法或代码块前加上synchronized关...
    99+
    2023-08-14
    Java
  • Java多线程实现第三方数据同步
    本文实例为大家分享了Java多线程实现第三方数据同步的具体代码,供大家参考,具体内容如下 一、场景 最近的一项开发任务是同步第三方数据,而第三方数据一般有存量数据和增量数据,存量数据...
    99+
    2022-11-13
    Java多线程数据同步 Java第三方数据同步 Java数据同步
  • Java多线程的同步优化的6种方案
    目录概述读写锁ReetrantReadWriteLock读写锁状态的设计写时复制写时复制的特点Java写时复制容器类减小锁的粒度减小锁的占有时间锁粗化ThreadLocal总结概述 ...
    99+
    2024-04-02
  • Java实现线程同步的四种方式总结
    目录什么是线程同步线程同步的几种方式1.使用synchronized关键字2.使用ReentrantLock3.使用原子变量实现线程同步4.ThreadLocal实现线程同步什么是线...
    99+
    2024-04-02
  • Java线程同步:实现多线程协作的方法与技巧
    在Java中,多线程编程是非常常见的,但是在多线程编程中,线程之间的同步是一个非常关键的问题。同步是指多个线程在执行过程中,能够协调和互相配合,以达到正确的执行结果。否则,会出现数据不一致、死锁等问题,影响程序的正确性和性能。 本文将介绍...
    99+
    2023-11-09
    同步 numy 日志
  • java中实现多线程同步的方法有哪些
    这篇文章将为大家详细讲解有关java中实现多线程同步的方法有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。为什么要线程同步因为当我们有多个线程要同时访问一个变量或对象时,如果这些线程中既...
    99+
    2023-05-31
    java 多线程同步 ava
  • Java实现多线程同步五种方法详解
    Java实现多线程同步的五种方法包括:1. synchronized关键字:使用synchronized关键字可以实现对共享资源的互...
    99+
    2023-08-14
    Java
  • Java编程中如何实现同步关键字的多线程同步?
    在Java编程中,多线程编程是一个非常常见的问题。由于多线程的特殊性质,会导致线程之间出现数据竞争和并发访问的问题。因此,在多线程编程中,我们需要使用同步机制来保证线程之间的安全性和正确性。Java中的同步机制主要有两种,一种是同步方法,...
    99+
    2023-11-11
    编程算法 同步 关键字
  • Java基础之多线程的三种实现方式
    目录一、前言二、继承Thread类实现多线程三、Runnable接口方式实现多线程四、Thread和Runnable的关系五、使用ExecutorService、Callable、F...
    99+
    2024-04-02
  • Java多线程协作作业之信号同步怎么实现
    本篇内容介绍了“Java多线程协作作业之信号同步怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、信号同步多线程很多时候是协作作业。...
    99+
    2023-06-30
  • Java多种方法实现等待所有子线程完成再继续执行
    现实世界中,我们常常需要等待其它任务完成,才能继续执行下一步。Java实现等待子线程完成再继续执行的方式很多。我们来一一查看一下。 Thread的join方法 该方法是Thread提供的方法,调用join()时,会阻塞主线程,等该Threa...
    99+
    2023-09-30
    java 开发语言
  • linux实现线程同步的方式有哪些
    本篇内容主要讲解“linux实现线程同步的方式有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“linux实现线程同步的方式有哪些”吧!6种方式:1、互斥锁,本质就是一个特殊的全局变量,拥有l...
    99+
    2023-07-02
  • C++实现线程同步的四种方式总结
    目录内核态互斥变量 事件对象资源信号量用户态关键代码内核态 互斥变量  互斥对象包含一个使用数量,一个线程ID和一个计数器。其中线程ID用于标识系统中的哪个线程当...
    99+
    2022-11-16
    C++线程同步方式 C++线程同步
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作