CountDownLatch的理解和例子

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

 

你可能感兴趣的:(并发)