Java并发编程之栅栏(CyclicBarrier)实例介绍

作者:junjie 时间:2023-12-01 19:48:53 

栅栏类似闭锁,但是它们是有区别的.

1.闭锁用来等待事件,而栅栏用于等待其他线程.什么意思呢?就是说闭锁用来等待的事件就是countDown事件,只有该countDown事件执行后所有之前在等待的线程才有可能继续执行;而栅栏没有类似countDown事件控制线程的执行,只有线程的await方法能控制等待的线程执行.

2.CyclicBarrier强调的是n个线程,大家相互等待,只要有一个没完成,所有人都得等着。

场景分析:10个人去春游,规定达到一个地点后才能继续前行.代码如下


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

class CyclicBarrierWorker implements Runnable {
    private int id;
    private CyclicBarrier barrier;

    public CyclicBarrierWorker(int id, final CyclicBarrier barrier) {
        this.id = id;
        this.barrier = barrier;
    }

    @Override
    public void run() {
        // TODO Auto-generated method stub
        try {
            System.out.println(id + " th people wait");
            barrier.await(); // 大家等待最后一个线程到达
        } catch (InterruptedException | BrokenBarrierException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}

public class TestCyclicBarrier {
    public static void main(String[] args) {
        int num = 10;
        CyclicBarrier barrier = new CyclicBarrier(num, new Runnable() {
            @Override
            public void run() {
                // TODO Auto-generated method stub
                System.out.println("go on together!");
            }
        });
        for (int i = 1; i <= num; i++) {
            new Thread(new CyclicBarrierWorker(i, barrier)).start();
        }
    }
}

输出


1 th people wait
2 th people wait
3 th people wait
4 th people wait
5 th people wait
7 th people wait
8 th people wait
6 th people wait
9 th people wait
10 th people wait
go on together!

标签:Java,并发编程,栅栏,CyclicBarrier
0
投稿

猜你喜欢

  • Java全面细致讲解==和equals的使用

    2021-08-20 05:28:43
  • java读取csv文件内容示例代码

    2023-03-13 22:09:14
  • Java异常学习之自定义异常详解

    2023-09-25 00:57:27
  • java中数组的定义及使用方法(推荐)

    2022-03-07 14:20:16
  • Java实现生成JSON字符串的三种方式分享

    2022-05-20 15:21:31
  • 一篇文章带你了解JVM垃圾回收

    2023-08-06 23:42:20
  • mybatis使用collection嵌套查询的实现

    2021-07-06 22:04:58
  • Java Socket编程实例(四)- NIO TCP实践

    2021-10-07 13:44:35
  • java反射应用详细介绍

    2022-06-14 04:59:45
  • Java多线程之同步工具类Exchanger

    2022-07-05 03:50:54
  • Java特性之注解和异常 Throwable

    2023-04-22 13:14:53
  • 浅谈Java中Int、Integer、Integer.valueOf()、new Integer()之间的区别

    2023-10-29 20:08:53
  • C#推送信息到APNs的方法

    2023-05-29 05:20:59
  • flutter实现发送验证码功能

    2023-07-05 19:03:12
  • C#中结构(struct)的部分初始化和完全初始化实例分析

    2021-11-01 16:33:36
  • java substring 截取字符串的方法

    2023-02-12 17:21:19
  • elasticsearch数据信息索引操作action support示例分析

    2022-03-18 02:09:07
  • spring cloud gateway 限流的实现与原理

    2023-04-10 16:47:56
  • springboot集成fastDfs过程代码实例

    2023-02-21 19:42:20
  • Spring创建Bean的6种方式详解

    2022-07-18 19:10:13
  • asp之家 软件编程 m.aspxhome.com