1. 首页
  2. 编程语言
  3. Java
  4. Java并发编程之CountDownLatch源码解析

Java并发编程之CountDownLatch源码解析

上传者: 2021-07-02 02:03:47上传 PDF文件 92.68 KB 热度 32次

可以用于实现一个线程等待所有子线程任务完成之后再继续执行的逻辑,也可以实现类似简易CyclicBarrier的功能,达到让多个线程等待同时开始执行某一段逻辑目的。可以看到CountDownLatch没有锁的概念,countDown方法可以被一个线程重复调用,只需要对state做reduce操作,而不用关心是谁做的reduce。其实很简单了,注意此时该方法的propagate参数值是1,那么就会进入到下面的if逻辑里,继续唤醒下一个node。当然,如果线程被中断唤醒,那么也会进入cancelAcquire中进行无效节点的移除逻辑。

用户评论