Java多线程学习之 CountDownLatch 用法介绍

在网上查找了一些资料,其原理及用法总结如下:

参考网址  点击打开链接

CountDownLatch是一种简单的同步模式,它让一个线程可以等待一个或多个线程完成它们的工作从而避免对临界资源并发访问所引发的各种问题。

使用场景:

      在一些应用场合中,需要等待某个条件达到要求后才能做后面的事情;同时当线程都完成后也会触发事件,以便进行后面的操作。 这个时候就可以使用CountDownLatch。CountDownLatch最重要的方法是countDown()和await(),前者主要是倒数一次,后者是等 待倒数到0,如果没有到达0,就只有阻塞等待了。

样例代码如下:

public class CountDownLatchTest {
	
	// 模拟了100米赛跑,10名选手已经准备就绪,只等裁判一声令下。当所有人都到达终点时,比赛结束。
	public static void main(String[] args) {
		// 开始的倒数锁 
		final CountDownLatch begin = new CountDownLatch(1);
		// 结束的倒数锁 
		final CountDownLatch end = new CountDownLatch(10);
		// 十名选手 
		ExecutorService executorService = Executors.newFixedThreadPool(10);
		
		for (int i = 1; i <= 10; i++) {
			final int no = i;
			Runnable run = new Runnable() {
				@Override
				public void run() {
					try {
						// 如果当前计数为零,则此方法立即返回。
                        // 等待
						begin.await();
						Thread.sleep((long) (Math.random() * 10000L));
						System.out.println(" No." + no + " arrived");
					} catch (InterruptedException e) {
						e.printStackTrace();
					} finally {
						// 每个选手到达终点时,end就减一
						end.countDown();
					}
				}
			};
			executorService.execute(run);
		}
		
		System.out.println("Game start...");
		// begin减一,开始游戏
		begin.countDown();
		try {
			end.await();
			// 等待end变为0,即所有选手到达终点
			System.out.println("Game over...");
		} catch (InterruptedException e) {
			e.printStackTrace();
		}finally {
			executorService.shutdown();
		}
	}
}
代码运行结果如下(因为每个线程运行的时间不同,每次运行运动员的名词是不一样的,到时Game start和Game over输出的顺序不会变):

Game start...
 No.1 arrived
 No.9 arrived
 No.10 arrived
 No.5 arrived
 No.6 arrived
 No.8 arrived
 No.4 arrived
 No.2 arrived
 No.7 arrived
 No.3 arrived
Game over...



你可能感兴趣的:(Java-多线程并发)