CountDownLatch如何使用?

2019-12-24  

  • CountDownLatch 可以起到发令枪的作用,JDK 1.5 开始提供
  • 用 CountDownLatch 实现并发访问,在写测试工具时希望达到某条件后,所有线程同时执行
  • 也可以用 CountDownLatch 实现,某线程等待其他线程完成,进行最后的统一处理

 

代码如下:

package constxiong.interview;

import java.util.concurrent.CountDownLatch;

/**
 * 测试使用100个线程,并发访问和等待多线程完成后处理
 * @author ConstXiong
 */
public class TestCountDownLatch2 {

	private static CountDownLatch cdl = new CountDownLatch(100);
	
	private static int count = 0;
	
	public static void main(String[] args) {
		testConcurrent();
//		testDoAfterOtherThreadComplete();
	}
	
	/**
	 * 测试并发  do something...
	 */
	private static void testConcurrent() {
		for (int i = 0; i < 100; i++) {
			//启动线程
			new Thread(() -> {
				try {
					//当发令枪计数未减到 0 之前线程都会在此阻塞
					cdl.await();
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
				System.out.println(Thread.currentThread().getName() + ":" + System.currentTimeMillis() + " do something...");
			}).start();
			
			//发令枪计数减 1
			cdl.countDown();
		}
	}
	
	//测试等待多线程完成后处理
	private static void testDoAfterOtherThreadComplete() {
		//启动 100 个线程,对 count 递增
		for (int i = 0; i < 100; i++) {
			new Thread(() -> {
				count++;
				//发令枪计数减 1
				cdl.countDown();
			}).start();
		}
		
		try {
			cdl.await();
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
		System.out.println("main thread print count : " + count);
	}
	
}

 

ConstXiong 备案号:苏ICP备16009629号-3