iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Java多线程中如何实现Phaser同步屏障
  • 811
分享到

Java多线程中如何实现Phaser同步屏障

2023-06-25 14:06:04 811人浏览 泡泡鱼
摘要

这篇文章将为大家详细讲解有关Java多线程中如何实现Phaser同步屏障,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。前言是否会遇到这样的场景,你向线程池提交了多个任务,你希望这批任务全部完

这篇文章将为大家详细讲解有关Java多线程中如何实现Phaser同步屏障,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

前言

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

你可能会使用线程计数的方式,等到计数器累加到提交的线程数量,然后通知。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();  }}

代码说明

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

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

验证一下

Java多线程中如何实现Phaser同步屏障

OK,没什么问题。

关于Java多线程中如何实现Phaser同步屏障就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: Java多线程中如何实现Phaser同步屏障

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

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

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java多线程中如何实现Phaser同步屏障
    这篇文章将为大家详细讲解有关Java多线程中如何实现Phaser同步屏障,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。前言是否会遇到这样的场景,你向线程池提交了多个任务,你希望这批任务全部完...
    99+
    2023-06-25
  • Java 多线程等待优雅的实现方式之Phaser同步屏障
    前言 是否会遇到这样的场景,你向线程池提交了多个任务,你希望这批任务全部完成后能够反向通知你。 你可能会使用线程计数的方式,等到计数器累加到提交的线程数量,然后通知。emmm,不是不...
    99+
    2024-04-02
  • Java如何实现多线程、线程同步
    这篇文章主要介绍了Java如何实现多线程、线程同步的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java如何实现多线程、线程同步文章都会有所收获,下面我们一起来看看吧。1 多线程1.1 进程进程:是正在运行的程...
    99+
    2023-06-30
  • Java编程中如何实现同步关键字的多线程同步?
    在Java编程中,多线程编程是一个非常常见的问题。由于多线程的特殊性质,会导致线程之间出现数据竞争和并发访问的问题。因此,在多线程编程中,我们需要使用同步机制来保证线程之间的安全性和正确性。Java中的同步机制主要有两种,一种是同步方法,...
    99+
    2023-11-11
    编程算法 同步 关键字
  • 在java项目中如何实现同步多线程
    本篇文章给大家分享的是有关在java项目中如何实现同步多线程,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 java多线程的同步方法实例代码先看一个段有关银行存钱的代...
    99+
    2023-05-31
    java 多线程 同步
  • Java中怎样实现多线程同步
    本篇文章给大家分享的是有关Java中怎样实现多线程同步,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。不同步时的代码Bank.java  package&nb...
    99+
    2023-06-17
  • Java中怎么实现多线程同步
    今天就跟大家聊聊有关Java中怎么实现多线程同步,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。让我们从JVM的角度来看看锁这个概念:在Java程序运行时环境中,JVM需要对两类线程共...
    99+
    2023-06-17
  • C++ 如何实现多线程与线程同步
    目录CreateThread 实现多线程:beginthreadex 实现多线程:CreateMutex 互斥锁实现线程同步:通过临界区实现线程同步:Semaphore 基于信号实现...
    99+
    2024-04-02
  • 利用Java如何实现同步线程
    利用Java如何实现同步线程?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。线程的同步是保证多线程安全访问竞争资源的一种手段。线程的同步是Java多线程编程的难点...
    99+
    2023-05-31
    java 线程 线程同步
  • 如何用 Java 同步在 IDE 中实现高效的多线程编程?
    Java 是一种广泛使用的编程语言,尤其在多线程编程方面有着广泛的应用。在多线程编程中,同步是一种非常重要的机制,可以确保多个线程之间的数据共享和协调。本文将介绍如何使用 Java 同步在 IDE 中实现高效的多线程编程。 一、同步机制的...
    99+
    2023-06-26
    同步 ide http
  • Java中怎么利用Synchronized实现多线程同步
    这期内容当中小编将会给大家带来有关Java中怎么利用Synchronized实现多线程同步,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。使用同步的原因 在系统中对访类要使用多线程进行访问; 在该类中有 类...
    99+
    2023-06-17
  • Java中多线程同步类 CountDownLatch
    在多线程开发中,常常遇到希望一组线程完成之后在执行之后的操作,java提供了一个多线程同步辅助类,可以完成此类需求:类中常见的方法:其中构造方法:CountDownLatch(int count) 参数count是计数器,一般用要执行线程的...
    99+
    2023-05-31
    countdownlatch ava tc
  • java中实现多线程同步的方法有哪些
    这篇文章将为大家详细讲解有关java中实现多线程同步的方法有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。为什么要线程同步因为当我们有多个线程要同时访问一个变量或对象时,如果这些线程中既...
    99+
    2023-05-31
    java 多线程同步 ava
  • VB.NET如何实现线程同步
    这篇文章主要介绍了VB.NET如何实现线程同步,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。VB.NET线程同步在VB.NET线程同步方面,VB.NET提供了几个方法。在上面...
    99+
    2023-06-17
  • Qt如何实现线程同步
    本篇内容介绍了“Qt如何实现线程同步”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!问题的提出线程安全的数据类可以提供一种便利的手段来进行线程...
    99+
    2023-06-19
  • Java多线程实现第三方数据同步
    本文实例为大家分享了Java多线程实现第三方数据同步的具体代码,供大家参考,具体内容如下 一、场景 最近的一项开发任务是同步第三方数据,而第三方数据一般有存量数据和增量数据,存量数据...
    99+
    2022-11-13
    Java多线程数据同步 Java第三方数据同步 Java数据同步
  • Java线程同步如何在不同线程中调用
    本篇文章为大家展示了Java线程同步如何在不同线程中调用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Java线程同步需要我们大家不断的学习,但是在学习的时候有些重要的代码还是需要注意,下面我们就来...
    99+
    2023-06-17
  • 怎么在java中实现多线程的互斥与同步
    这篇文章将为大家详细讲解有关怎么在java中实现多线程的互斥与同步,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、线程互斥与同步互斥:指的是多个线程不能同时访问共享变量同步:指的是多个线程...
    99+
    2023-06-15
  • java多线程实现同步锁卖票实战项目
    目录同步概念与方法:窗口类:测试类:同步概念与方法: 窗口类: public class Ticket implements Runnable{ int ticket...
    99+
    2023-01-28
    java 同步锁卖票 java 同步锁
  • Java实现多线程同步的方法有哪些
    Java实现多线程同步的方法有以下几种:1. 使用synchronized关键字:通过在方法或代码块前加上synchronized关...
    99+
    2023-08-14
    Java
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作