谈谈你对CountDownLatch的理解(不看后悔,一看必懂)

版权声明:本文为博主原创文章,未经博主允许可以转载。 https://blog.csdn.net/qq_36071795/article/details/83932376

CountDownLatch是java.util.concurrent包中一个工具类。它能够使一个或者多个线程等待另外一些线程完成各自的工作之后,再继续执行

使用CountDownLatch的一些情景:

①需要去解析一个Excel的数据,为了更快的解析,每个sheet都使用一个线程进行解析,但是最后汇总数据的工作需要等待每个sheet的解析工作完成之后才能进行

②开启多个线程分块传输一个大数据包,每个线程只传输固定的一截,最后由另外一个线程拼接所有的分块

③启动一个服务时,主线程需要等待多个组件加载完毕,之后再继续执行。

CountDownLatch类实际上是使用计数器的方式去控制的计数器初始值为线程的数量。当每一个线程完成自己任务后,计数器的值就会减一。当计数器的值为0时,表示所有的线程都已经完成了任务,然后在CountDownLatch上等待的线程就可以恢复执行任务。

CountDownLatch的不足

CountDownLatch是一次性的,计数器的值只能在构造方法中初始化一次,之后没有任何机制再次对其设置值,当CountDownLatch使用完毕后,它不能再次被使用

public class CountDownLatchDemo {

public static void main(String[] args) throws InterruptedException{

CountDownLatch countDownLatch = new CountDownLatch(2){

@Override

public void await() throws InterruptedException {

super.await();

System.out.println(Thread.currentThread().getName() +  " count down is ok");

}

};

Thread thread1 = new Thread(new Runnable() {

@Override

public void run() {

//do something

try {

Thread.sleep(1000);

} catch (InterruptedException e) {

e.printStackTrace();

}

System.out.println(Thread.currentThread().getName() + " is done");

countDownLatch.countDown();

}

}, "thread1");

 

Thread thread2 = new Thread(new Runnable() {

@Override

public void run() {

//do something

try {

Thread.sleep(2000);

} catch (InterruptedException e) {

e.printStackTrace();

}

System.out.println(Thread.currentThread().getName() + " is done");

countDownLatch.countDown();

}

}, "thread2");

 

thread1.start();

thread2.start();

countDownLatch.await();

}

}

输出结果

thread1 is done

thread2 is done

main count down is ok

猜你喜欢

转载自blog.csdn.net/qq_36071795/article/details/83932376
今日推荐