JDK5.0新特性系列---11.5.2线程 同步装置之CountDownLatch

 

 

import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

/**
 * CountDownLatch维护一个计数器,等待这个CountDownLatch的线程必须等到计数器为0时才可以继续.
 * 以下实例模拟服务器的启动,假设启动一个服务器需要初始化3个组件,当3个组件初始化完毕后,服务器才算成功启动.
 */
/**
 * 使用CountDownLatch的关键技术点如下:
 * 1.构造CountDownLatch对象时,需要指定计数器的初始值,该值必须大于等于0,一旦对象被创建,其初始值将不能被改变.
 * 2.CountDownLatch的await方法使当前线程进入等待状态,直到计数器为0
 * 3.CountDownLatch的 和countDown方法使计数器减1.
 */
public class CountDownLatchTest {
  /** 初始化组件的线程 */
  public static class ComponentThread implements Runnable {
    CountDownLatch latch; //计数器
    int ID; //组件ID

    //构造方法
    public ComponentThread(CountDownLatch latch, int ID) {
      this.latch = latch;
      this.ID = ID;
    }

    public void run() {
      //初始化组件
      System.out.println("Initializing component " + ID);
      try {
        Thread.sleep(500 * ID);
      }
      catch (InterruptedException e) {}
      System.out.println("Component " + ID + " initialized!");
      latch.countDown(); //将计数器减1
    }
  }

  /** 启动服务器 */
  public static void startServer() throws Exception {
    System.out.println("Server is starting.");
    //初始化一个初始值为3的CountDownLatch
    CountDownLatch latch = new CountDownLatch(3);
    //启动3个线程分别去3个组件
    ExecutorService service = Executors.newCachedThreadPool();
    service.submit(new ComponentThread(latch, 1));
    service.submit(new ComponentThread(latch, 2));
    service.submit(new ComponentThread(latch, 3));
    service.shutdown();
    latch.await();//等待3个组件的初始化工作都完成
    System.out.println("Server is up!");//当所需的三个组件都完成时,Server就可以继续了
  }

  public static void main(String... args) throws Exception {
    CountDownLatchTest.startServer();
  }
}

 

时间: 2024-11-09 01:54:58

JDK5.0新特性系列---11.5.2线程 同步装置之CountDownLatch的相关文章

JDK5.0新特性系列---11.5.1线程 同步装置之Semaphore

    import java.util.ArrayList; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Semaphore; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock;   /**

JDK5.0新特性系列---11.5.4线程 同步装置之Exchanger

/**  * Exchanger让两个线程互换信息  * 实例模拟服务生和顾客,服务生往空杯子中倒水,顾客从装满水的杯子中喝水,然后互换杯子,服务生接着倒水,顾客接着喝水.  */ /**  * 使用Exchanger的关键技术点如下:  * 1.初始化Exchanger对象时,可以通过泛型指定杯子能交换的信息类型.如"new Exchanger<String>;"表示只能交换String类型的信息  * 2.Exchanger的exchange方法表示当前线程准备交换信息

JDK5.0新特性系列---11.6线程 BlockingQueue

  importjava.util.concurrent.ArrayBlockingQueue; import java.util.concurrent.BlockingQueue; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors;   /**     本例介绍一个特殊的队列:BlockingQueue,如果BlockQueue是空的,从BlockingQueue取东西的操作将会

JDK5.0新特性系列---11.3线程 锁Lock

  import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Future; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReadWriteLock; import java.util.concurrent.locks.Reent

JDK5.0新特性系列---11.1线程 Callable和Future

  import java.util.concurrent.Callable; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Future;   /**     从本节开始,主要介绍J2SE5.0与线程相关的新特性,新的线程类主要集中在java.util.concurrent 包中,本节实例将介绍如何使用java.uti

JDK5.0新特性系列---11.2线程 任务执行架构

  import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Future; import java.util.concurrent.ScheduledExecu

JDK5.0新特性系列---11.4线程 Condition

  import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.locks.Condition; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock;   /**  *有时候线程取得lock后需要在一定条件下才能

JDK5.0新特性系列---目录

  JDK5.0新特性系列---目录   JDK5.0新特性系列---1.自动装箱和拆箱   JDK5.0新特性系列---2.新的for循环 JDK5.0新特性系列---3.枚举类型 JDK5.0新特性系列---4.静态导入 JDK5.0新特性系列---5.可变长参数Varargs JDK5.0新特性系列---6.格式化输出 JDK5.0新特性系列---7.使用ProcessBuilder执行本地命令 JDK5.0新特性系列---8.泛型编程 JDK5.0新特性系列---9.注释功能Annota

JDK5.0新特性系列---10.监控与管理虚拟机

  import java.lang.management.ClassLoadingMXBean; import java.lang.management.CompilationMXBean; import java.lang.management.GarbageCollectorMXBean; import java.lang.management.ManagementFactory; import java.lang.management.MemoryMXBean; import java.