cyclicbarrier_Java并发– CyclicBarrier示例

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的想法。

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


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

cyclicbarrier

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

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

相关文章

【XSY2720】区间第k小 整体二分 可持久化线段树

题目描述 给你你个序列&#xff0c;每次求区间第\(k\)小的数。 本题中&#xff0c;如果一个数在询问区间中出现了超过\(w\)次&#xff0c;那么就把这个数视为\(n\)。 强制在线。 \(n\leq 100000,a_i<n,w\leq n\) 题解 考虑整体二分。 先看看离线要怎么做。 现在我们要计算每…

php队列失败是指什么,队列是什么意思

队列是一种特殊的线性表。它只允许在表的前端(front)进行删除操作&#xff0c;而在表的后端(rear)进行插入操作&#xff0c;和栈一样&#xff0c;队列是一种操作受限制的线性表&#xff1b;进行插入操作的端称为队尾&#xff0c;进行删除操作的端称为队头&#xff1b;队列中没有…

从In Memory Data Grid,Apache Ignite快速入门

IMDG或内存数据网格不是内存中关系数据库&#xff0c;NOSQL数据库或关系数据库。 它是另一种软件数据存储库。 数据模型分布在单个位置或多个位置的许多服务器上。 这种分布称为数据结构。 这种分布式模型被称为“无共享”架构。 IMDG具有以下特征&#xff1a; 所有服务器可以…

python字典合并几种方式对比,Python合并两个字典的常用方法与效率比较

本文实例讲述了Python合并两个字典的常用方法与效率比较。分享给大家供大家参考。具体分析如下&#xff1a;下面的代码举例了5种合并两个字典的方法&#xff0c;并且做了个简单的性能测试#!/usr/bin/pythonimport timedef f1(d1,d2):return dict(d1,**d2)def f2(d1,d2):return …

91.91p10.space v.php,luogu P1091 合唱队形

任务计划推了很久才做www从两头开始的单调上升队列没啥可说的#include#includeusing namespace std;#define maxn 110int a[maxn];int f[2][maxn];int ans;int main() {int n;scanf("%d",&n);for(int i 1; i < n; i)scanf("%d",&a[i]);a[0] a…

oracle查询大小写敏感参数,让Oracle 大小写敏感 表名 字段名 对像名

一、解决方案1、在表名、字段名、对象名上加上双引号&#xff0c;即可实现让oracle大小写区分。2、但是这又引起了另一个问题&#xff1a;在数据库操作中&#xff0c;sql语句中相应的表名、字段名、对象名上一定要加双引号。解决办法是&#xff1a;使用"\"转义。如&a…

BZOJ 2097 [Usaco2010 Dec]Exercise 奶牛健美操

【题意】 给出一棵树。现在可以在树中删去m条边&#xff0c;使它变成m1棵树。要求最小化树的直径的最大值。 【题解】 二分答案。$Check$的时候用$DP$&#xff0c;记录当前节点每个儿子的直径$v[i]$&#xff0c;如果$v[i]1>mid$&#xff0c;那么就断掉连向儿子的这条边。如果…

将原生SQL功能Hibernate到您的Spring Data Repository中

JPA为您提供NamedNativeQuery以便使用本机SQL。 但是&#xff0c;用法并不方便&#xff0c;特别是当您需要在本机SQL中映射多个实体时。 您必须定义一组SqlResultSetMapping映射&#xff0c;这很容易出错。 对于以前使用过Hibernate本机SQL功能的用户&#xff0c;您会发现它比J…

daterangepicker双日历插件的使用

今天主要是由于项目的需要&#xff0c;做了一个daterangepicker双日历插件&#xff0c;做出来的效果如下&#xff1a; 个人感觉这个daterangepicker双日历插件很好用&#xff0c;并且实现起来也不是很麻烦&#xff0c;我是根据它的官方文档去写的&#xff0c;并将Bootstrap也整…

php 递归展现城市信息,PHP 递归兑现层级树状展现数据

PHP 递归实现层级树状展现数据?$arr[id],fid > $arr[fid],name > $arr[name],);}// 将数据按照缩进简单排列 见图1function data2arr($tree, $rootId 0, $level 0) {foreach($tree as $leaf) {if($leaf[fid] $rootId) {echo str_repeat( , $level) . $leaf[id] . .…

牛客网 2018年全国多校算法寒假训练营练习比赛(第五场) H.Tree Recovery-完全版线段树(区间更新、区间求和)...

H.Tree Recovery时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒空间限制&#xff1a;C/C 131072K&#xff0c;其他语言262144K64bit IO Format: %lld链接&#xff1a;https://www.nowcoder.com/acm/contest/77/H来源&#xff1a;牛客网题目描述 You have N integers, A1,…

面向对象的代码生成方法

代码生成是减少无聊任务的不健康负担的一种常用方法&#xff0c;这些任务常常使我们急切的代码苦恼。 我见过的许多代码生成框架都使用模板替换重复方法&#xff0c;在该方法中&#xff0c;您可以编写一个模板&#xff0c;以了解生成的代码文件的外观&#xff0c;然后替换某些关…

t oracle删除吗,Oracle 11g 手工建库与删库

Oracle 11g 手工建库与删库在前一篇文章中提到阅读Oracle 11gR2 Administrator‘sGuide(文档编号E25494-01)时&#xff0c;简单描述了DDL_LOCK_TIMEOUT参数。在Oracle 11gR2Administrator‘s Guide文档的chapter 2 Creating and Configuring anOracle Database章节时&#xff0…

oracle连接满报错日志,Oracle归档日志满了导致Oracle连接(ORA-00257)报错处理

最近一段时间&#xff0c;有收到一台Oracle服务器的连接告警&#xff0c; 刚刚开始还以为是Oracle的监听被关闭导致&#xff0c;结果连上服务器看下Oracle的监听进程正常&#xff0c;自己连接一次发现有报ORA-00257错&#xff0c;又去监控系统中在看下日志再用sqlplus连上Oracl…

微信登陆超时 重新登录_重新登录:重新登录

微信登陆超时 重新登录嗨&#xff0c;我再次感到非常高兴&#xff0c;认为日志记录是任何应用程序设计和开发的固有部分。 我是坚强的基础知识的忠实拥护者&#xff0c;以我的拙见&#xff0c;日志记录是任何企业级应用程序中经常被忽略但基本的关键要素之一。 我已经写在此之前…

HBase错误:ERROR: Can't get master address from ZooKeeper; znode data == null 解决办法

一、问题背景 使用命令 $ hbase shell 进入hbase的shell之后使用create命令创建表时出现错误&#xff1a;ERROR: Cant get master address from ZooKeeper; znode data null 二、解决方法 检查${HBASE_HOME}/conf/hbase-site.html的属性hbase.rootdir <property><na…

oracle中OEM证书失效怎么办,安全证书过期怎么办 网站安全证书失效处理【解决方法】...

安全证书过期怎么办?所谓的网站安全证书是通过在客户端浏览器和Web服务器之间建立一条SSL安全通道保证了双方传递信息的安全性&#xff0c;而且用户可以通过服务器证书验证他所访问的网站是否真实可靠。下面&#xff0c;我们就来看看网站安全证书失效处理方法。一、计算机中的…

JavaFX缺少的功能调查:表视图

JavaFX的TableView&#xff08;和TreeTableView&#xff09;赢得了我最近的“ JavaFX缺失功能”调查以及许多后续讨论中&#xff08;尤其是苏黎世JavaFX Meetup小组的成员 &#xff09;中提到最多的控件的价格。 &#xff09;。 我想原因之一是一个简单的事实&#xff0c;即几乎…

快速幂矩阵快速幂

快速幂 题目链接&#xff1a;https://www.luogu.org/problemnew/show/P1226 快速幂用了二分的思想&#xff0c;即将\(a^{b}\)的指数b不断分解成二进制的形式&#xff0c;然后相乘累加起来&#xff0c;就是用\(a^{b/2}a^{b/2}\)去求\(a{^b}\)。 例如:\(a^{11}a^{(2^02^12^3)}\)…

前端项目里常见的十种报错及其解决办法

错误一&#xff1a;Uncaught TypeError: Cannot set property onclick of nullat operate.js:86图片.png原因&#xff1a;当js文件放在head里面时&#xff0c;如果绑定了onclick事件&#xff0c;就会出现这样的错误&#xff0c;是因为W3School的写法是浏览器先加载完按钮节点才…