Java多线程之CountDownLatch学习
给出官网上的例子:http://docs.oracle.com/javase/7/docs/api/java/util/concurrent/CountDownLatch.html
Java中concurrent包中的CountDownLatch类说白了就是一个计数器,我们可以通过设置参数来进行计数,每次只能有一个线程去操作这个计数器,通过CountDown这个函数使得计数器的值减小,当计数器的值为0时,阻塞于await方法的线程才能得以执行。
例子:下面的程序中的主线程阻塞于await方法, 只有当5个线程都执行完了,主线程才能继续执行。
package com.test; import java.util.Random; import java.util.concurrent.CountDownLatch; public class CountDownLatchDemo { private static final int N = 5; private CountDownLatch waitCountDownLatch = null; public static void main(String[] args) throws InterruptedException { new CountDownLatchDemo(); } public CountDownLatchDemo() throws InterruptedException { waitCountDownLatch = new CountDownLatch(N); for (int i = 0; i < N; ++i) { new MyThread(i).start(); } waitCountDownLatch.await(); System.out.println("所有线程已经执行完成"); } class MyThread extends Thread { private int id; MyThread(int id) { this.id = id; } public void run() { try { System.out.println("线程 " + id + "正在执行" ); Thread.sleep(new Random().nextInt(2) * 1000); } catch (InterruptedException ex) { ex.printStackTrace(); } finally { waitCountDownLatch.countDown(); } } } }
注:CountDownLatch类中有以下几个方法
void await()等待,直到计数器中的值减为0。
boolean await(long timeout, TimeUnit unit)可以自己设置超时时间,一旦超过这个时间,await线程被唤醒,如果返回true,说明计数器为0,否则,不为0。
void countDown()使得计数器的值减1。
long getCount()得到当前计数器的值。