CountDownLatch的理解和例子

    技术2022-07-11  86

    CountDownLatch内部通过共享锁实现。在创建CountDownLatch实例时,需要传递一个int型的参数:count,该参数为计数器的初始值,也可以理解为该共享锁可以获取的总次数。

    当某个线程调用await()方法,程序首先判断count的值是否为0,如果不会0的话则会一直等待直到为0为止。

    当其他线程调用countDown()方法时,则执行释放共享锁状态,使count值 - 1。

    当在创建CountDownLatch时初始化的count参数,必须要有count线程调用countDown方法才会使计数器count等于0,锁才会释放,前面等待的线程才会继续运行。

    注意CountDownLatch不能回滚重置。

     

    package com.xmg.thread; import java.util.concurrent.CountDownLatch; public class CountDownLatchRoom { private static CountDownLatch countDownLatch = new CountDownLatch(5); static class BossThread extends Thread{ @Override public void run() { System.out.println("boss 到达,等待"+ countDownLatch.getCount() +"人开会"); try { //boss 线程调用await()方法,等待countDownLatch计数为0继续执行。 countDownLatch.await(); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("人已经到齐,开会"); } } static class EmployeeThread extends Thread{ @Override public void run() { System.out.println(Thread.currentThread().getName()+"到达会议室。。。"); //调用countDown()使计数减1 countDownLatch.countDown(); } } public static void main(String[] args) { new BossThread().start(); for(int i=0;i<countDownLatch.getCount();i++){ new EmployeeThread().start(); } } }

     

    Processed: 0.019, SQL: 10