解释一下CountDownLatch概念?
CountDownLatch这个类能够使一个线程等待其他线程完成各自的工作后再执行。例如,应用程序的主线程希望在负责启动框架服务的线程已经启动所有的框架服务之后再执行。
CountDownLatch是通过一个计数器来实现的,计数器的初始值为线程的数量。每当一个线程完成了自己的任务后,计数器的值就会减1。当计数器值到达0时,它表示所有的线程已经完成了任务,然后在闭锁上等待的线程就可以恢复执行任务。
CountDownLatch 和CyclicBarrier的不同之处?
CyclicBarrier 实现一致性,
CyclicBarrier:可看成是个障碍,所有的线程必须到齐后才能一起通过这个障碍
CountDownLatch简单计数。
CountDownLatch:我把他理解成倒计时锁
CountDownLatch 类中主要的方法?
CountDownLatch.await()方法。这样主线程的操作就会在这个方法上阻塞,直到其他线程完成各自的任务
CountDownLatch.countDown()方法来完成的;每调用一次这个方法,在构造函数中初始化的count值就减1。所以当N个线程都调 用了这个方法,count的值等于0,然后主线程就能通过await()方法,恢复执行自己的任务
给出一些CountDownLatch使用的例子?
题目:实现一个容器,提供两个方法,add,size。写两个线程,线程1添加10个元素到容器中,线程2实现监控元素的个数,当个数到5个时,线程2给出提示并结束。
package com.boco.mis;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.CountDownLatch;
public class T7 {
List<Object> lists = new ArrayList<Object>();
public void add(Object o){
lists.add(o);
}
public int getSize(){
return this.lists.size();
}
public static void main(String[] args) {
T7 t = new T7();
CountDownLatch cdl = new CountDownLatch(1);
new Thread(()->{
if(t.getSize()!=5){
try {
cdl.await();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
System.err.println("线程2 结束");
}).start();
new Thread(()->{
for (int i = 0; i < 10; i++) {
t.add(new Object());
System.err.println(t.getSize());
if(t.getSize()==5){
cdl.countDown();
}
try {
Thread.sleep(1000);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}).start();
}
}