返回顶部
首页 > 资讯 > 精选 >如何在Java中利用CyclicBarrier实现并发编程
  • 943
分享到

如何在Java中利用CyclicBarrier实现并发编程

java并发编程cyclicbarrier 2023-05-31 09:05:40 943人浏览 安东尼
摘要

如何在Java中利用CyclicBarrier实现并发编程?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。  使用JAVA编写并发程序的时候,我们需要仔

如何在Java中利用CyclicBarrier实现并发编程?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

  使用JAVA编写并发程序的时候,我们需要仔细去思考一下并发流程的控制,如何让各个线程之间协作完成某项工作。有时候,我们启动N个线程去做一件事情,只有当这N个线程都达到某一个临界点的时候,我们才能继续下面的工作,就是说如果这N个线程中的某一个线程先到达预先定义好的临界点,它必须等待其他N-1线程也到达这个临界点,接下来的工作才能继续,只要这N个线程中有1个线程没有到达所谓的临界点,其他线程就算抢先到达了临界点,也只能等待,只有所有这N个线程都到达临界点后,接下来的事情才能继续。

一、场景描述

有四个游戏玩家玩游戏,游戏有三个关卡,每个关卡必须要所有玩家都到达后才能允许通过。其实这个场景里的玩家中如果有玩家A先到了关卡1,他必须等到其他所有玩家都到达关卡1时才能通过,也就是说线程之间需要相互等待。这和CountDownLatch的应用场景有区别,CountDownLatch里的线程是到了运行的目标后继续干自己的其他事情,而这里的线程需要等待其他线程后才能继续完成下面的工作。

二、CyclicBarrier介绍

CyclicBarrier 的字面意思是可循环使用(Cyclic)的屏障(Barrier)。它要做的事情是,让一组线程到达一个屏障(也可以叫同步点)时被阻塞,直到最后一个线程到达屏障时,屏障才会开门,所有被屏障拦截的线程才会继续干活。CyclicBarrier默认的构造方法是CyclicBarrier(int parties),其参数表示屏障拦截的线程数量,每个线程调用await方法告诉CyclicBarrier我已经到达了屏障,然后当前线程被阻塞。

CyclicBarrier类有两个常用的构造方法:

1. CyclicBarrier(int parties)

这里的parties也是一个计数器,例如,初始化时parties里的计数是3,于是拥有该CyclicBarrier对象的线程当parties的计数为3时就唤醒,注:这里parties里的计数在运行时当调用CyclicBarrier:await()时,计数就加1,一直加到初始的值

2. CyclicBarrier(int parties, Runnable barrierAction)

这里的parties与上一个构造方法的解释是一样的,这里需要解释的是第二个入参(Runnable barrierAction),这个参数是一个实现Runnable接口的类的对象,也就是说当parties加到初始值时就出发barrierAction的内容。

代码示例

package com.itmyhome;import java.util.concurrent.BrokenBarrierException;import java.util.concurrent.CyclicBarrier;class Player implements Runnable {  private CyclicBarrier cyclicBarrier;  private int id;  public Player(int id, CyclicBarrier cyclicBarrier) {    this.cyclicBarrier = cyclicBarrier;    this.id = id;  }  @Override  public void run() {    try {      System.out.println("玩家" + id + "正在玩第一关...");      cyclicBarrier.await();      System.out.println("玩家" + id + "进入第二关...");    } catch (InterruptedException e) {      e.printStackTrace();    } catch (BrokenBarrierException e) {      e.printStackTrace();    }  }}public class CyclicBarrierTest {  public static void main(String[] args) {    // CyclicBarrier cyclicBarrier = new CyclicBarrier(4);    CyclicBarrier cyclicBarrier = new CyclicBarrier(4,        new Runnable() {          @Override          public void run() {            System.out.println("所有玩家进入第二关!");          }        });    for (int i = 0; i < 4; i++) {      new Thread(new Player(i, cyclicBarrier)).start();    }  }}

输出结果:

玩家0正在玩第一关...玩家3正在玩第一关...玩家2正在玩第一关...玩家1正在玩第一关...所有玩家进入第二关!玩家3进入第二关...玩家1进入第二关...玩家2进入第二关...玩家0进入第二关...

CyclicBarrier和CountDownLatch的区别

  • CountDownLatch: 一个线程(或者多个), 等待另外N个线程完成某个事情之后才能执行。

  • CyclicBarrier: N个线程相互等待,任何一个线程完成之前,所有的线程都必须等待。

  • CountDownLatch的计数器只能使用一次。而CyclicBarrier的计数器可以使用reset() 方法重置。所以CyclicBarrier能处理更为复杂的业务场景,比如如果计算发生错误,可以重置计数器,并让线程们重新执行一次。

  • CountDownLatch:减计数方式,CyclicBarrier:加计数方式

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注编程网精选频道,感谢您对编程网的支持。

--结束END--

本文标题: 如何在Java中利用CyclicBarrier实现并发编程

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

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

猜你喜欢
  • 如何在Java中利用CyclicBarrier实现并发编程
    如何在Java中利用CyclicBarrier实现并发编程?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。  使用JAVA编写并发程序的时候,我们需要仔...
    99+
    2023-05-31
    java 并发编程 cyclicbarrier
  • 如何使用Java高并发编程CyclicBarrier
    本篇内容介绍了“如何使用Java高并发编程CyclicBarrier”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!什么是CyclicBarr...
    99+
    2023-06-15
  • 怎么在Java中利用LockSupport类实现并发编程
    今天就跟大家聊聊有关怎么在Java中利用LockSupport类实现并发编程,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、LockSupport类的属性private ...
    99+
    2023-06-15
  • 如何使用NPM在Java和NumPy中实现并发编程?
    随着计算机科学的不断发展,多核处理器的出现使得并发编程成为了一种重要的编程方式。并发编程可以大大提高程序的性能和响应能力,减少等待时间,提高程序的可靠性。但是,并发编程也面临着很多挑战,如竞态条件、死锁等问题。为了解决这些问题,我们需要使...
    99+
    2023-07-23
    numy 并发 npm
  • Java如何实现并发编程?
    Java如何实现并发编程? 在今天的软件开发领域中,多核处理器已经成为了主流。因此,实现并发编程已经成为了必要的技能。Java是一种支持并发编程的编程语言,它提供了一些重要的工具和API来帮助开发人员实现并发编程。本文将介绍Java中实现并...
    99+
    2023-08-28
    numy shell 并发
  • C++并发编程:如何利用多核CPU实现并发?
    c++++ 并发编程通过创建线程、互斥锁和条件变量来充分利用多核 cpu 的优势。创建线程允许任务并行执行。互斥锁充当锁,确保共享数据不会被多个线程同时访问,从而避免数据损坏。条件变量用...
    99+
    2024-05-01
    c++ 并发编程 并发访问
  • Java并发编程回环屏障CyclicBarrier实例分析
    本文小编为大家详细介绍“Java并发编程回环屏障CyclicBarrier实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java并发编程回环屏障CyclicBarrier实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入...
    99+
    2023-06-30
  • 多线程并发编程如何在Java项目中实现
    本篇文章为大家展示了多线程并发编程如何在Java项目中实现 ,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、多线程操作系统有两个容易混淆的概念,进程和线程。进程:一个计算机程序的运行实例,包含了需...
    99+
    2023-05-31
    java 多线程 并发编程
  • Java中的并发编程:如何利用数组容器实现高效率?
    随着计算机硬件的发展,多核处理器已经成为了主流。这也意味着,在编写Java程序时,我们需要更多地考虑并发编程。在这篇文章中,我们将探讨如何使用Java中的数组容器来实现高效率的并发编程。 Java中的数组容器 在Java中,数组容器指的是...
    99+
    2023-09-19
    并发 数组 容器
  • 怎么在Java中使用CountDownLatch实现并发编程
    本篇文章为大家展示了怎么在Java中使用CountDownLatch实现并发编程,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Java是什么Java是一门面向对象编程语言,可以编写桌面应用程序、We...
    99+
    2023-06-14
  • 怎么在Java中使用ReentrantLock实现并发编程
    这篇文章给大家介绍怎么在Java中使用ReentrantLock实现并发编程,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、首先看图二、lock()跟踪源码这里对公平锁和非公平锁做了不同实现,由构造方法参数决定是否公...
    99+
    2023-06-15
  • 如何在Go语言中实现并发编程?
    Go语言是一种现代化的编程语言,它的并发编程特性使其成为开发高性能网络应用和分布式系统的理想选择。本文将介绍Go语言中的并发编程,包括协程、通道和锁等重要概念,以及如何使用它们来实现高效的并发编程。 协程 协程是Go语言中并发编程的核心概...
    99+
    2023-06-21
    并发 ide npm
  • Java和Git如何实现并发编程?
    随着现代软件开发项目的复杂性不断增加,编写高效的并发程序变得至关重要。Java和Git是两个非常流行的编程工具,它们都有一些强大的特性,可以帮助我们实现并发编程。 Java并发编程 Java是一种广泛使用的面向对象编程语言,它提供了大量的...
    99+
    2023-10-16
    git django 并发
  • 在java项目中使用线程池实现并发编程
    今天就跟大家聊聊有关在java项目中使用线程池实现并发编程,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、任务和执行策略之间的隐性耦合Executor可以将任务的提交和任务的执行策...
    99+
    2023-05-31
    java 线程池 并发编程
  • 如何在golang中利用Select Channels Go并发式编程实现任务调度
    在Go语言中,可以使用select和channel来实现任务调度。下面是一个示例代码,演示如何使用select和channel来实现...
    99+
    2023-10-20
    Golang
  • 如何在Java中使用Django进行并发编程?
    在Java开发中,Django是一个非常流行的Python web框架,它的并发编程能力也备受推崇。本篇文章将介绍如何在Java中使用Django进行并发编程,同时穿插一些演示代码。 一、Django的并发编程能力 Django的并发编程能...
    99+
    2023-10-16
    git django 并发
  • 如何在Go中实现高效的并发编程?
    在Go语言中,实现高效的并发编程是其最大的特色之一。Go提供了一系列丰富的并发编程工具,如goroutine、channel等,使得Go的并发编程变得十分简单和高效。本文将介绍如何在Go中实现高效的并发编程,旨在帮助读者更好地利用Go的并发...
    99+
    2023-08-14
    并发 bash 容器
  • 如何在Python中使用路径API实现并发编程?
    Python是一门流行的编程语言,被广泛应用于各种领域。在并发编程中,路径API是一个非常有用的工具,可以方便地操作文件和目录。本文将介绍如何在Python中使用路径API实现并发编程。 首先,我们需要了解一些基本的路径API。Python...
    99+
    2023-06-29
    并发 path api
  • 如何在 Python 中使用 npm 实现高效并发编程?
    Python 是一种优秀的编程语言,同时也是一种比较灵活的语言,可以与其它语言进行混合编程。npm 是 Node.js 的包管理器,它提供了大量的库和工具,可以帮助开发者更加高效地完成项目。在本文中,我们将介绍如何在 Python 中使用 ...
    99+
    2023-07-25
    npm 学习笔记 并发
  • 如何在Java中利用File类实现一个io编程
    本篇文章为大家展示了如何在Java中利用File类实现一个io编程,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、首先了解文件流的相关概念:2、文件File类的基本用法public cl...
    99+
    2023-05-31
    java file类 io编程
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作