Java并发– CyclicBarrier示例

Java中的CyclicBarrier是JDK 5中java.util.Concurrent包中引入的同步器,以及其他并发实用程序(如Counting Semaphore , BlockingQueue , ConcurrentHashMap等)。CyclicBarrier与CountDownLatch类似,我们在上一篇文章中看到了它,它允许多个线程等待彼此(障碍),然后继续。 CoundDownLatch和CyclicBarrier之间的区别也是Java中一个非常流行的多线程面试问题 。 CyclicBarrier是并发程序的自然要求,因为一旦单个任务完成,它就可以用于执行任务的最后一部分。 等待彼此到达屏障的所有线程都称为方,使用要等待的方数初始化CyclicBarrier,然后通过调用CyclicBarrier.await()方法来彼此等待线程,这是Java中的阻塞方法,直到所有线程都阻塞或各方调用await()。 通常,调用await()会喊出Thread正在等待屏障。 await()是一个阻塞调用,但可以被其他线程超时或中断。 在此Java并发性教程中,我们将看到CyclicBarrier的简单示例,在该示例上,三个线程将互相等待,然后再继续操作。
Java中 CountDownLatch CyclicBarrier 之间的区别
在上一篇文章中,我们了解了如何使用CountDownLatch来实现多个相互等待的线程 。 如果您查看CyclicBarrier,它也做同样的事情,但是有不同之处,一旦计数达到零,您将无法重用 CountDownLatch ,而您可以通过调用reset()方法重用CyclicBarrier来将Barrier重置为其初始状态。 这意味着CountDownLatch适用于一次事件,例如应用程序启动时间,而CyclicBarrier可以用于周期性事件,例如同时计算大问题的解决方案等。如果您想了解有关Java中线程和并发性的更多信息,也可以查看我有关何时在Java中使用Volatile变量以及Java 如何同步的文章 。
Java中的 CyclicBarrier –示例
这是Java中CyclicBarrier的一个简单示例,在该示例中,我们使用3个方初始化了CyclicBarrier,这意味着为了越过障碍,3个线程需要调用await()方法。 每个线程都在短时间内调用await方法,但是直到所有3个线程都到达障碍为止,它们才继续进行,一旦所有线程到达障碍,障碍都获得代理,并且每个线程从此处开始执行。 通过以下CyclicBarrier示例在Java中的输出,可以很清楚地看到它:
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
import java.util.logging.Level;
import java.util.logging.Logger;/**
* Java program to demonstrate how to use CyclicBarrier in Java. CyclicBarrier is a 
* new Concurrency Utility added in Java 5 Concurrent package.
*
* @author Javin Paul
*/public class CyclicBarrierExample {//Runnable task for each thread
private static class Task implements Runnable {private CyclicBarrier barrier;public Task(CyclicBarrier barrier) {
this.barrier = barrier;
}@Override
public void run() {
try {
System.out.println(Thread.currentThread().getName() + " is waiting on barrier");
barrier.await();
System.out.println(Thread.currentThread().getName() + " has crossed the barrier");
} catch (InterruptedException ex) {
Logger.getLogger(CyclicBarrierExample.class.getName()).log(Level.SEVERE, null, ex);
} catch (BrokenBarrierException ex) {
Logger.getLogger(CyclicBarrierExample.class.getName()).log(Level.SEVERE, null, ex);
}
}
}public static void main (String args[]) {//creating CyclicBarrier with 3 parties i.e. 3 Threads needs to call await()
final CyclicBarrier cb = new CyclicBarrier(3, new Runnable(){
@Override
public void run(){
//This task will be executed once all thread reaches barrier
System.out.println("All parties are arrived at barrier, lets play");
}
});//starting each of thread
Thread t1 = new Thread(new Task(cb), "Thread 1");
Thread t2 = new Thread(new Task(cb), "Thread 2");
Thread t3 = new Thread(new Task(cb), "Thread 3");t1.start();
t2.start();
t3.start();}
}

输出:

Thread 1 is waiting on barrier
Thread 3 is waiting on barrier
Thread 2 is waiting on barrier
All parties are arrived at barrier, lets play
Thread 3 has crossed the barrier
Thread 1 has crossed the barrier
Thread 2 has crossed the barrier
何时 在Java中 使用 CyclicBarrier
鉴于CyclicBarrier的性质, 与Java 7的fork-join框架类似,实现map reduce任务非常方便,在Java 7中 ,将大任务分解为较小的部分,并完成需要从单个小任务输出的任务,例如要计算印度的人口,您可以有4个线程来计算北,南,东和西的人口,完成后它们可以互相等待,当最后一个线程完成任务时,主线程或任何其他线程可以从每个区域中添加结果并打印总人口。 您可以在Java中使用CyclicBarrier:
1)实现多人游戏,直到所有玩家都加入后才能开始。
2)通过将其分解为较小的单个任务来执行冗长的计算,通常要实施Map reduce技术。
Java CyclicBarrier的 重点
1.一旦所有线程到达barrier,CyclicBarrier即可执行完成任务,可以在创建CyclicBarrier时提供。
2.如果用3个参与者初始化了CyclicBarrier,则意味着3个线程需要调用await方法来打破该障碍。
3. 线程将在await()上阻塞 ,直到各方到达障碍,另一个线程中断或等待超时为止。
4.如果另一个线程中断正在等待屏障的线程,它将抛出BrokernBarrierException,如下所示:
java.util.concurrent.BrokenBarrierException
at java.util.concurrent.CyclicBarrier.dowait(CyclicBarrier.java:172)
at java.util.concurrent.CyclicBarrier.await(CyclicBarrier.java:327)
5. CyclicBarrier .reset()将Barrier置于其初始状态,正在等待或尚未达到屏障的其他线程将以java.util.concurrent.BrokenBarrierException终止。
以上就是Java中带有示例的CyclicBarrier。 我们还看到了Java中CountDownLatch和CyclicBarrier之间的区别,并且了解了一些可以在Java并发代码中使用CyclicBarrier的想法。

参考: Javarevisited博客上的JCG合作伙伴 Javin Paul提供的Java 5中的CyclicBarrier示例–并发教程 。


翻译自: https://www.javacodegeeks.com/2012/08/java-concurrency-cyclicbarrier-example.html

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

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

相关文章

JasperReports JSF插件用例–简单列表报告

这是JasperReports JSF插件系列的第一篇“用例文章” ,我将专注于一个简单的需求,并且我将进一步深入。 起点是我们已经为图书商店完成的项目设置,我将向其中添加一个列表,其中包含在数据库中注册的其他图书,该列表也将…

ER图流程图

ER图:ER图分为实体、属性、关系三个核心部分。实体是长方形体现,而属性则是椭圆形,关系为菱形。 图书馆管理系统流程图(图片源于网上):对于程序员来说,我们要知道:整个系统中&#x…

php源码仿三一重工,织梦仿三一重工业大学气企业网站php源码

★模板引荐★源码称呼:仿三一重工业大学气企业网站php源码仿三一重工业大学气企业网站php源码,尝试完备无错,兼容合流欣赏器。模板包括安置证明,并包括尝试数据。本模板鉴于DEDECms 5.7 GBK安排,须要 UTF-8版本的请本人…

php树莓派魔镜,用树莓派和显示器制作一面“魔镜”

所需要的材料一台显示器一块和显示器大小相同的双面镜一些2*4米的细木条树莓派机器必要组件(电源、HDMI线、usb无线网卡、键盘)木工工具(锯子、磨砂机、螺丝刀)螺丝、液态钉子选一个合适的显示器镜子的大小完全由显示器的类型和大小决定,所以我希望得到一个尽量大的…

【数字图像处理】[3]--直方图规范化

【数字图像处理】[3]--直方图规范化直方图规范化出现的原因是因为直方图均衡只能产生出固定的图像,不满足于需求,有时我们需要让直方图变成特定的直方图,于是有了直方图规范化原理:可能只看公式没什么感觉,我们来举一个…

JavaFX 2.0布局窗格– GridPane

毫无疑问, GridPane是JavaFX 2.0中功能最强大,最灵活的布局窗格。 它在由行和列组成的灵活网格中布置其子项,与Swing的GridBagLayout或HTML的表格模型非常相似。 这种方法使该窗格非常适合于任何形式的表单(例如网站上的联系表单&…

java ui自动化测试脚本,如何用Airtest编写UI自动化脚本(示例代码)

前言游戏并不像app一样直接把渲染树节点暴露出来,这就造成游戏UI自动化在元素定位上的不方便性,不过依赖airtest的图片识别,我们可以直接跳过元素检查,以图片对比的形式进行自动化,虽然效率可能会低一些,但…

django实现瀑布流、组合搜索、阶梯评论、验证码

django实现图片瀑布流布局 我们在一些图片网站上经常会看到,满屏都是图片,而且图片都大小不一,却可以按空间排列。默认一个div是占用一行,当想把div里的图片并排显示的时候,只能使用float属性,但是&#xf…

带有docx4j的Java Word(.docx)文档

几个月前,我需要创建一个包含许多表和段落的动态Word文档。 过去,我曾使用POI来实现此目的,但是我发现它很难使用,并且在创建更复杂的文档时对我来说效果不佳。 因此,对于这个项目,经过一番搜索&#xff0c…

mysql中distinct关键字,MySQL关键字Distinct的详细介绍

DDLPrepare SQL:?Prepare Data:?查询数据如下图所示:第一种情况,使用Distinct关键字,查询单列数据,如下图所示:结果:对 name 字段进行去重处理,符合预期期望&#xff0…

(二)windows下安装PHPCMS V9

一、准备工作 搭建环境 :参考:Windows下搭建PHP开发环境及相关注意事项PHPCMS V9 :下载适合自己 PHPCMS V9 版本到本地或服务器,下载地址:http://www.phpcms.cn/html/download/说明:官方提供了 2 种不同的编码。包括 G…

JavaFX 2.0布局窗格– HBox和VBox

如果要对JavaFX 2.0中所有不同的布局窗格进行概述,或者想了解有关它们的一些基本知识,请参阅我以前的文章《 JavaFX 2.0中的布局窗格》 。 布局窗格HBox和VBox绝对是JavaFX 2.0中最基本的布局容器。 如您所知,它们的用途是将所有子级布置在一…

单片机串行通信全解析

1.什么是串行通信? 串行通信(英语:Serial communication)是指在计算机总线或其他数据通道上,每次传输一个位元数据,并连续进行以上单次过程的通信方式。与之对应的是并行通信,它在串行端口上通过…

java type 类型,java中的泛型类型与Type接口

假设我们定义了一个Room的类,表示一个房间public classRoom(){}由于我们建造好房间是,不知道房间以后的用途,他可能用来住人,也有可能用来放货物,因此需要用到泛型。但是我们可能想获取Room这个房间里面进来的的东西的…

vray学习笔记(3)-多维子材质是个什么东西

多维子材质是个什么东西?为什么出现这个概念? 在3dsmax官方网站,我们可以看到它的定义: The Multi/Sub-Object material lets you assign different materials at the sub-object level of your geometry. 意思是多维子材质这个概…

Hello JavaFX 2.0:命令行介绍

我从博客文章Hello JavaFX 2.0:NetBeans 7.1 beta的介绍中,从NetBeans 7.1 beta的角度看了一个无处不在的Hello World示例的简单JavaFX版本。 在本文中,我将介绍仅使用命令行工具通过JavaFX实现的Hello World版本。 JavaFX 2.0 API文档包括ja…

oracle列分区,Oracle数据库分区--实例

分区表通过对分区列进行判断,把满足不同条件的分区列对应的记录保存在不同的分区中。一、何为分区表什么情况下会使用分区表?表中已有大量数据,或预计到表中将会保存大量的数据可以按照预期(月份、区域、dml)对表中的数据执行查询和更新什么是…

ZK实际应用:MVVM –与ZK客户端API一起使用

在之前的文章中,我们使用ZK的MVVM实现了以下功能: 将数据加载到表中 使用表单绑定保存数据 删除条目并以编程方式更新视图 ZK MVVM和ZK MVC实现方式之间的主要区别是,我们不直接在controller(ViewModel)类中访问和操…

终极JPA查询和技巧列表–第1部分

我们可以在Internet上找到一些JPA“如何做”,在本博客的此处,教您如何使用JPA执行多项任务。 通常,我看到有人问有关使用JPA进行查询的问题。 通常,为了回答此类问题,提供了几个链接,以尝试找到该问题的解决…

Spring集成–第2节–更多世界

这是Spring Integration Session 1的后续活动 第一部分是使用Spring Integration的简单Hello World应用程序。 我想通过考虑其他一些方案来进一步介绍它。 因此,对Hello World应用程序的第一个更改是添加网关组件。 要快速重新访问较早的测试程序,请执行…