Java并发编程:CountDownLatch线程等待同步辅助类

原文地址:https://docs.oracle.com/javase/7/docs/api/java/util/concurrent/CountDownLatch.html

java.util.concurrent中

CountDownLatch类


  •  
    公共类CountDownLatch 
    扩展了Object

   允许一个或多个线程等待直到在其他线程中执行的一组操作完成的同步辅助。

  • CountDownLatch用给定的计数初始化。由于await方法的调用,方法阻塞直到当前计数达到零countDown(),之后释放所有等待的线程并await立即返回任何后续的调用 。这是一次性现象 - 计数无法重置。如果您需要重置计数的版本,请考虑使用CyclicBarrier

    CountDownLatch是一种通用的同步工具,可用于多种用途。甲 CountDownLatch一个的计数初始化作为一个简单的开/关锁存器,或门:所有线程调用await ,直到它被一个线程调用开在栅极等待countDown()。一个CountDownLatch初始化为ň 可以用来做一个线程等待,直到ň线程完成一些动作,或某些动作已经完成N次。

    a的一个有用属性CountDownLatch是它不需要线程调用countDown等待计数在继续之前达到零,它只是阻止任何线程继续经过await直到所有线程都可以通过。

    示例用法:这是一对类,其中一组工作线程使用两个倒计时锁存器:

    • 第一个是启动信号,阻止任何工人继续工作,直到驱动程序准备好继续进行;
    • 第二个是完成信号,允许驾驶员等到所有工人完成。
    class Driver { // ...
       void main() throws InterruptedException {
         CountDownLatch startSignal = new CountDownLatch(1);
         CountDownLatch doneSignal = new CountDownLatch(N);
    
         for (int i = 0; i < N; ++i) // create and start threads
           new Thread(new Worker(startSignal, doneSignal)).start();
    
         doSomethingElse();            // don't let run yet
         startSignal.countDown();      // let all threads proceed
         doSomethingElse();
         doneSignal.await();           // wait for all to finish
       }
     }
    
     class Worker implements Runnable {
       private final CountDownLatch startSignal;
       private final CountDownLatch doneSignal;
       Worker(CountDownLatch startSignal, CountDownLatch doneSignal) {
          this.startSignal = startSignal;
          this.doneSignal = doneSignal;
       }
       public void run() {
          try {
            startSignal.await();
            doWork();
            doneSignal.countDown();
          } catch (InterruptedException ex) {} // return;
       }
    
       void doWork() { ... }
     }
     

    另一个典型的用法是将问题分成N个部分,用执行该部分的Runnable描述每个部分并对锁存器进行倒计时,并将所有Runnables排队到Executor。当所有子部件都完成后,协调线程将能够通过等待。(当线程必须以这种方式重复倒计时,而是使用a CyclicBarrier。)

    class Driver2 { // ...
       void main() throws InterruptedException {
         CountDownLatch doneSignal = new CountDownLatch(N);
         Executor e = ...
    
         for (int i = 0; i < N; ++i) // create and start threads
           e.execute(new WorkerRunnable(doneSignal, i));
    
         doneSignal.await();           // wait for all to finish
       }
     }
    
     class WorkerRunnable implements Runnable {
       private final CountDownLatch doneSignal;
       private final int i;
       WorkerRunnable(CountDownLatch doneSignal, int i) {
          this.doneSignal = doneSignal;
          this.i = i;
       }
       public void run() {
          try {
            doWork(i);
            doneSignal.countDown();
          } catch (InterruptedException ex) {} // return;
       }
    
       void doWork() { ... }
     } 

    内存一致性影响:在计数达到零之前,调用之前的线程中的 操作countDown() 发生在await()另一个线程中的对应成功返回之后的操作 之前

    以来:

    1.5

  • 方法摘要

    方法 
    修饰符和类型方法和描述
    voidawait()

    除非线程被中断,否则导致当前线程等待锁存器倒计数到零。

    booleanawait(long timeout, TimeUnit unit)

    导致当前线程等待,直到锁存器倒计数到零,除非线程被中断,或者指定的等待时间过去。

    voidcountDown()

    减少锁存器的计数,如果计数达到零则释放所有等待的线程。

    longgetCount()

    返回当前计数。

    StringtoString()

    返回标识此锁存器的字符串及其状态。

  • 构造函数摘要

    构造函数 
    构造函数和描述
    CountDownLatch(int count)

    CountDownLatch使用给定计数构造初始化。

  • 方法细节

    • 等待

      public void await()
                 抛出InterruptedException
      除非线程被中断,否则导致当前线程等待锁存器倒计数到零。

      如果当前计数为零,则此方法立即返回。

      如果当前计数大于零,则当前线程将被禁用以进行线程调度,并且在发生以下两种情况之一之前处于休眠状态:

      • 由于countDown()方法的调用,计数达到零 ; 要么
      • 其他一些线程会中断 当前线程。

      如果当前线程:

      • 在进入此方法时设置其中断状态; 要么
      • 在等待时 被打断
      InterruptedException抛出 然后清除当前线程的中断状态。

      抛出:

      InterruptedException - 如果当前线程在等待时被中断

    • 等待

      public boolean await(long timeout,
                   TimeUnit  unit)
                    抛出InterruptedException
      导致当前线程等待,直到锁存器倒计数到零,除非线程被中断,或者指定的等待时间过去。

      如果当前计数为零,则此方法立即返回值true

      如果当前计数大于零,则当前线程因线程调度而被禁用,并且在发生以下三种情况之一之前处于休眠状态:

      • 由于countDown()方法的调用,计数达到零 ; 要么
      • 其他一些线程会中断 当前线程; 要么
      • 指定的等待时间过去了。

      如果计数达到零,则该方法返回值true

      如果当前线程:

      • 在进入此方法时设置其中断状态; 要么
      • 在等待时 被打断
      InterruptedException抛出 然后清除当前线程的中断状态。

      如果指定的等待时间过去,则false 返回该值。如果时间小于或等于零,则该方法将不会等待。

      参数:

      timeout - 等待的最长时间

      unittimeout参数的时间单位

      返回:

      true如果计数达到零并且false 在计数达到零之前等待时间已过去

      抛出:

      InterruptedException - 如果当前线程在等待时被中断

    • 倒数

      public void countDown()
      减少锁存器的计数,如果计数达到零则释放所有等待的线程。

      如果当前计数大于零,则递减。如果新计数为零,则重新启用所有等待线程以进行线程调度。

      如果当前计数等于零,则没有任何反应。

    • getCount将

      public long getCount()
      返回当前计数。

      此方法通常用于调试和测试目的。

      返回:

      目前的数量

    • public  String  toString()

      返回标识此锁存器的字符串及其状态。括号中的状态包括String "Count =" 后跟当前计数。

      覆盖:

      toString 在班上 Object

      返回:

      标识此锁存器的字符串及其状态

  • 构造函数详细信息

    • CountDownLatch

      public CountDownLatch(int count)

      CountDownLatch使用给定计数构造初始化。

      参数:

      countcountDown()线程可以通过之前必须调用的次数await()

      抛出:

      IllegalArgumentException- 如果count是否定的

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值