zookeeper系列——CountDownLatch的理解和使用

前言

在学习zookeeper相关知识点的时候遇到了一个类叫做CountDownLatch,因为没使用过该类所以不是太理解。为了不至于影响后面的学习,决定先把CountDownLatch学习一番。

一、CountDownLatch的概念

首先字面上翻译过来的意思是倒计时闭锁,翻译过来似乎好理解一些。倒计时即依次减少,锁呢也好理解在编程中经常提到的一个概念,起到了一个同步阻塞的作用。是否如此呢?再看下官网的解释:A synchronization aid that allows one or more threads to wait until a set of operations being performed in other threads completes. 翻译:一种同步辅助,允许一个或多个线程等待,直到在其他线程中执行的一组操作完成。

详细的说明下,CountDownLatch是在java1.5被引入的,跟它一起被引入的并发工具类还有CyclicBarrier、Semaphore、ConcurrentHashMap和BlockingQueue,它们都存在于java.util.concurrent包下。CountDownLatch这个类能够使一个线程等待其他线程完成各自的工作后再执行。

例如,应用程序的主线程希望在负责启动框架服务的线程已经启动所有的框架服务之后再执行。 CountDownLatch是通过一个计数器来实现的,计数器的初始值为线程的数量。每当一个线程完成了自己的任务后,计数器的值就会减1。当计数器值到达0时,它表示所有的线程已经完成了任务,然后在闭锁上等待的线程就可以恢复执行任务。总结下就是:CountDownLatch是一种java.util.concurrent包下一个同步工具类,它允许一个或多个线程等待直到在其他线程中一组操作执行完成。

二、CountDownLatch的用法

需要借助CountDownLatch的构造器进行使用,CountDownLatch.java类中定义的构造函数: 构造器中的计数值(count)实际上就是闭锁需要等待的线程数量。这个值只能被设置一次,而且CountDownLatch没有提供任何机制去重新设置这个计数值。 与CountDownLatch的第一次交互是调用CountDownLatch.await() 方法。这样会使得调用该法方法的当前线程在这个方法上阻塞,直到其他线程完成各自的任务调用CountDownLatch.countDown()方法,使CountDownLatch构造方法的参数最终递减为0,受到阻塞的那个线程才会被释放。当然其他的线程必须引用相同的闭锁对象,因为他们需要通知CountDownLatch对象,他们已经完成了各自的任务。这种通知机制是通过 CountDownLatch.countDown()方法来完成的;每调用一次这个方法,在构造函数中初始化的count值就减1。所以当N个线程都调用了这个方法,count的值等于0,然后阻塞线程就能通过await()方法,恢复执行自己的任务。

三、CountDownLatch的使用场景

1 实现最大的并行性

注意是并行性,不是并发,强调的是多个线程在某一时刻同时开始执行。类似于赛跑,将多个线程放到起点,等待发令枪响,然后同时开跑。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值