CountDownLatch介绍
CountDownLatch类位于java.util.concurrent包下,利用它可以实现类似计数器的功能。比如有一个任务A,它要等待其他4个任务执行完毕之后才能执行,此时就可以利用CountDownLatch来实现这种功能了。
CountDownLatch类只提供了一个构造器:
public CountDownLatch(int count) { }; //参数count为计数值
然后下面这3个方法是CountDownLatch类中最重要的方法:
public void await() throws InterruptedException { }; //调用await()方法的线程会被挂起,它会等待直到count值为0才继续执行
public boolean await(long timeout, TimeUnit unit) throws InterruptedException { }; //和await()类似,只不过等待一定的时间后count值还没变为0的话就会继续执行
public void countDown() { }; //将count值减1
CountDownLatch开发使用
应用场景:如果有业务需要等另外一个业务执行完,这时候就可以使用CountDownLatch来做限制,实例如下:
public class CountDownLatchTest {
private static ExecutorService executorService = Executors.newFixedThreadPool(2);
public static void main(String[] args) {
CountDownLatch countDownLatch = new CountDownLatch(2);
AtomicInteger atomicInteger = new AtomicInteger();
System.out.println("start...");
for(int i=0;i<2;i++){
executorService.submit(new Runnable() {
@Override
public void run() {
System.out.println("do something..."+Thread.currentThread().getName());
atomicInteger.incrementAndGet();
countDownLatch.countDown();
}
});
}
try {
countDownLatch.await();
} catch (InterruptedException e) {
e.printStackTrace();
}
//先执行完子线程,才会执行继续执行主线程
System.out.println("end...");
executorService.shutdown();
}
}
喜欢的可以点个赞,欢迎大家交流!