使用java并发工具栅栏(CyclicBarrier)实现多线程等待,同一时刻执行共同任务

  CyclicBarrier,名字就是循环栅栏,栅栏显而易见就是拦住一堆"事情",这里"事情"就是线程,在未达到栅栏指定的线程数时,所有线程都要等待,达到指定数目,共同执行下面的任务。api文档解释:

A synchronization aid that allows a set of threads to all wait for each other to reach a common barrier point. CyclicBarriers are useful in programs involving a fixed sized party of threads that must occasionally wait for each other. The barrier is called cyclic because it can be re-used after the waiting threads are released.

  下面设定一个场景,在运动场上,所有运动员自由走到起跑线,在发令枪发令之前,可以自由热身,但是一旦所有队员已经走到起跑线并准备好,裁判发号施令。程序如下:

  

package com.smikevon.concurrent.tools;

import java.util.Random;
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;

/**
 * @description: 要求:十个运动员要进行百米赛跑,在赛前运动员各自进行自己的热身运动,然后统一起跑,裁判才开始记时。
 * @date       : 2014年9月17日 下午4:22:15
 */
public class TestCyclicBarrier {

    public static void main(String[] args) throws InterruptedException {

        String[] children = {"小明(1号)","小强(2号)","小海(3号)","小龙(4号)","小武(5号)","小勇(6号)","小鹏(7号)","小飞(8号)","小峰(9号)","小涛(10号)"};

        final Random random = new Random(System.currentTimeMillis());

        final CyclicBarrier barrier = new CyclicBarrier(10,new Runnable() {
            public void run() {
                Thread.currentThread().setName("裁判");
                doing("各就各位,预备,跑");

            }
        });

        //让10个运动员动起来
        for(String child : children){
            new Thread(new Runnable() {
                public void run() {
                    try {
                        doing("我要开始做我的热身运动!");
                        int time = random.nextInt(20000);
                        Thread.sleep(time);
                        doing("我已经做完了热身运动!共耗时"+Long.parseLong(time+"")/1000+"秒!");
                        //等待其他线程执行
                        barrier.await();
                        doing("我已经准备好,当前时间是:"+System.currentTimeMillis());
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    } catch (BrokenBarrierException e) {
                        e.printStackTrace();
                    }
                }
            },child).start();
        }
    }

    /**
     * @Description:打印出线程的名字
     * @param msg
     * @returType:void
     */
    public static void doing(String msg){
        System.out.println(Thread.currentThread().getName()+":"+msg);
    }

}
时间: 2024-12-14 22:34:02

使用java并发工具栅栏(CyclicBarrier)实现多线程等待,同一时刻执行共同任务的相关文章

Java并发工具类CyclicBarrier

CyclicBarrier同步屏障 java并发工具类中有一个叫做CyclicBarrier的类,与CountDownLatch类似,都可以实现线程间的同步,但是差别是CyclicBarrier是可重置的同步屏障. 想象一个场景,有N个人不同时间走到一扇门,因为门需要N个人合力才能推开,所以人不足N个时,只能阻塞在此,等到N个人都到了之后,可以推开门,继续进行之前的工作.CyclicBarrier就是这扇门. 看看下面的代码,定义了一个线程数为2的,CyclicBarrier,并在主线程和另外一

Java并发工具类(一)等待多线程完成的CountDownLatch

作用 CountDownLatch是一个同步工具类,它允许一个或多个线程一直等待,直到其他线程的操作执行完后再执行 简介 CountDownLatch是在java1.5被引入的,存在于java.util.concurrent包下,它允许1个或者多个线程一直等待,直到一组操作执行完成.它初始一个整数值,此值是线程将要等待的操作数.当某个线程为了想要执行这些操作而等待时, 它要使用 await()方法.此方法让线程进入休眠直到操作完成. 当某个操作结束,它使用countDown() 方法来减少Cou

25.大白话说java并发工具类-CountDownLatch,CyclicBarrier,Semaphore,Exchanger

1. 倒计时器CountDownLatch 在多线程协作完成业务功能时,有时候需要等待其他多个线程完成任务之后,主线程才能继续往下执行业务功能,在这种的业务场景下,通常可以使用Thread类的join方法,让主线程等待被join的线程执行完之后,主线程才能继续往下执行.当然,使用线程间消息通信机制也可以完成.其实,java并发工具类中为我们提供了类似"倒计时"这样的工具类,可以十分方便的完成所说的这种业务场景. 为了能够理解CountDownLatch,举一个很通俗的例子,运动员进行跑

Java 并发工具CountDownLatch和CyclicBarrier 原理解析

[TOC] Java 并发工具CountDownLatch和CyclicBarrier 原理解析 一,简介 CountDownLatch 允许一个或者多个线程等待其他线程完成操作. CyclicBarrier 的字面意思是可循环使用(Cyclic)的屏障(Barrier).它要做的事情是,让一组线程达到一个屏障(也可以叫同步点)时被阻塞,直到最后一个线程到达屏障时,屏障才会开门,所有被屏障拦截的线程才会继续运行. 二,代码演示 CountDownLatchDemo public class Co

Java并发工具类 - CountDownLatch

Java并发工具类 - CountDownLatch 1.简介 CountDownLatch是Java1.5之后引入的Java并发工具类,放在java.util.concurrent包下面 http://docs.oracle.com/javase/7/docs/api/java/util/concurrent/package-summary.html 官方API. CountDownLatch能够使一个或多个线程等待其他线程完成各自的工作后再执行:CountDownLatch是JDK 5+里面

玩转Java并发工具,精通JUC,成为并发多面手

玩转Java并发工具,精通JUC,成为并发多面手 深度解密JUC库,提升五位一体的并发综合实力 使用场景+作用+底层原理逐一解读,吃透JUC并发包 掌握丰富的并发工具,解决实际问题,面试.工作轻松搞定 链接:https://pan.baidu.com/s/1ehvQUq9LUmmrZHYH7_DuGw 提取码:jyfs 全网程序学习资料,包含Java后端.前端.人工智能大数据.Python.数据结构和算法.运维.测试.面试相关等课程,所有视频资料均无加密,普通播放器就可播放,加客服微信coder

Java并发工具类(二)同步屏障CyclicBarrier

作用 CyclicBarrier是一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point),才继续执行. 简介 CyclicBarrier 的字面意思是可循环使用(Cyclic)的屏障(Barrier).它要做的事情是,让一组线程到达一个屏障(也可以叫同步点)时被阻塞,直到最后一个线程到达屏障时,屏障才会开门,所有被屏障拦截的线程才会继续干活.CyclicBarrier默认的构造方法是CyclicBarrier(int parties),其参数

【多线程与并发】Java并发工具类

主要有两类 ①并发流程控制相关:CountDownLatch.CyclicBarrier.Semaphore ②线程间交换数据相关:Exchanger: CountDownLatch 作用:允许一个或多个线程等待其他线程完成操作 使用步骤: ①定义一个CountDownLatch(称为计数器),并指定等待次数: ②在合适的时机将计数器减1: ③在需要等待所有任务结束的位置,调用await()方法: 根据JDK中的说明文档整理的两个例子: 例子1: public class CountDownLa

多线程之美3一Java并发工具类

目录结构 一.简介 1.1.Semaphore 1.2.CountDownLatch 1.3.CyclicBarrier 二.信号量Semaphore 2.1.构造方法 2.2.主要方法 2.3.示例代码 三.计数器CountDownLatch 3.1.主要方法 3.2.示例代码1 3.3.示例代码2 四.栅栏类CyclicBarrier 4.1.构造方法 4.2.示例代码 一.简介 1.1. Semaphore 信号量,见文知义,常用于并发控制中的限流作用,我理解是限定数量的共享锁机制.该共享