CountDownLatch、CyclicBarrier

CountDownLatch

JDK1.5被引入,在java.util.concurrent包下,其初始化一个数值(>=0),使用countDown将计数器数值减1,使用awit方法阻塞线程。当计数器数值为0时,解除阻塞。

常用方法:

public CountDownLatch(int count) // 构造方法:初始化计数器数量
public void await()    // 阻塞线程
public boolean await(long timeout, TimeUnit unit) // 阻塞线程,但等待指定时间计数器仍然不等于0就不等了,继续执行
public void countDown() // 计数器值减1
public long getCount() // 获取当前值

例如:当前主线程要做四件事,分别是ABCD,但必须执行完ABC后才能执行D(ABC并发执行)

public static void main(String[] args) throws InterruptedException {
        CountDownLatch countDownLatch = new CountDownLatch(3);
        String[] list = new String[]{"A", "B", "C"};
        for (String str : list) {
            new Thread(() -> {
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println("线程:" + str + "执行");
                countDownLatch.countDown();
            }).start();
        }
        countDownLatch.await();
        System.out.println("\nA、B、C全部执行完毕后,执行D");
    }

运行结果:

 CyclicBarrier

直译“循环屏障”,也是在JDK1.5被引入,在java.util.concurrent包下。

当一组线程到达一个屏障时被阻塞(await方法),直到这一组所有的线程全部到达时,屏障就会开门,所有的线程继续向下执行;此时屏障被重置,下次仍可循环使用。

常用方法

public CyclicBarrier(int parties) // 构造方法:初始化参与线程的个数
public CyclicBarrier(int parties, Runnable barrierAction) // 构造方法:初始化参与线程个数,并且在个数范围内的线程全部执行完毕后,执行Runnable中的任务
public int await() // 屏障点,计数器加1
public int await(long timeout, TimeUnit unit) // 屏障点,计数器加1,如果超出指定时间,则抛出TimeoutException

 例如:ABC先执行第一阶段任务,必须三个人都执行完了,才能一起开始执行第二阶段任务

public static void main(String[] args) throws InterruptedException {
        String[] list = new String[]{"A", "B", "C"};
        CyclicBarrier cyclicBarrier = new CyclicBarrier(list.length, () -> {
            System.out.println("\nA、B、C全部执行完第一阶段任务\n");
        });
        for (String str : list) {
            new Thread(() -> {
                try {
                    Thread.sleep(1000);
                    System.out.println("线程:" + str + "开始执行第一阶段任务");
                    cyclicBarrier.await();
                    Thread.sleep(1000);
                    System.out.println("线程:" + str + "开始执行第二阶段任务");
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }).start();
        }
    }

 运行结果:

 总结:

  1. CountDownLatch等待线程完毕后执行;Cyclicbarrier等待线程执行到某个状态后再一起执行
  2. CountDownLatch基于AQS实现,Cyclicbarrier基于ReentrantLock实现
  3. CountDownLatch只能执行一次,计数器到0后结束,无法重置;Cyclicbarrier计数器到0后重置,可循环使用
  4. CountDownLatch调用countDown方法-1;Cyclicbarrier调用await方法+1

CountDownLatch源码分析请看我的另一篇博客:

理解AQS(AbstractQueuedSynchronizer)源码分析_γìńɡ雄尐年ぐ的博客-CSDN博客java.util.concurrent.locks下public abstract class AbstractQueuedSynchronizer extends AbstractOwnableSynchronizer implements java.io.Serializable {/** * The synchronization state. */ private volatile int state;}其继承的https://blog.csdn.net/qq_26012495/article/details/117936194

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CountDownLatch 是一个计数器,它可以让一个或多个线程等待其他线程执行完毕后再继续执行。它的主要方法是 countDown() 和 await(),其中 countDown() 用于计数减一,await() 用于等待计数器变为0。与 CountDownLatch 相比,CyclicBarrier 的主要区别在于它可以重复使用,而且所有线程必须同时到达栅栏处才能继续执行后续任务。CyclicBarrier 的重要方法是 await(),并且可以通过构造方法传入一个 Runnable,在所有线程都到达栅栏状态时优先执行该动作。CyclicBarrier 内部使用 ReentrantLock 和 Condition 实现等待和唤醒的功能,通过维护一个 count 变量来记录还有多少个线程没有到达栅栏处。 <span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [CountDownLatchCyclicBarrier](https://blog.csdn.net/weixin_44442186/article/details/123985119)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [JUC多线程:CountDownLatchCyclicBarrier、Semaphore同步器原理总结](https://blog.csdn.net/a745233700/article/details/120688546)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值