Java CountDownLatch应用

Java的concurrent包里面的CountDownLatch其实可以把它看作一个计数器,只不过这个计数器的操作是原子操作,同时只能有一个线程去操作这个计数器,也就是同时只能有一个线程去减这个计数器里面的值。

      你可以向CountDownLatch对象设置一个初始的数字作为计数值,任何调用这个对象上的await()方法都会阻塞,直到这个计数器的计数值被其他的线程减为0为止。

      CountDownLatch的一个非常典型的应用场景是:有一个任务想要往下执行,但必须要等到其他的任务执行完毕后才可以继续往下执行。假如我们这个想要继续往下执行的任务调用一个CountDownLatch对象的await()方法,其他的任务执行完自己的任务后调用同一个CountDownLatch对象上的countDown()方法,这个调用await()方法的任务将一直阻塞等待,直到这个CountDownLatch对象的计数值减到0为止。

      举个例子,有五个工人在为老板干活,这个老板有一个习惯,就是当五个工人把一天的活都干完了的时候,他就来检查所有工人所干的活。

 1 import java.util.Random;
 2 import java.util.concurrent.CountDownLatch;
 3 import java.util.concurrent.ExecutorService;
 4 import java.util.concurrent.Executors;
 5 import java.util.concurrent.TimeUnit;
 6 
 7 public class CountDownLatchTest {
 8 
 9     private static CountDownLatch downLatch = new CountDownLatch(5);
10 
11     public static void main(String[] args) {
12         ExecutorService executorService = Executors.newFixedThreadPool(10);
13         executorService.submit(new Boss());
14         executorService.submit(new Worker("1"));
15         executorService.submit(new Worker("2"));
16         executorService.submit(new Worker("3"));
17         executorService.submit(new Worker("4"));
18         executorService.submit(new Worker("5"));
19         executorService.shutdown();
20     }
21 
22     static class Worker implements Runnable{
23         private String name ;
24 
25         public Worker(String name){
26             this.name = name;
27         }
28         @Override
29         public void run() {
30             try {
31                 TimeUnit.SECONDS.sleep(new Random().nextInt(10));
32             } catch (InterruptedException e) {
33                 e.printStackTrace();
34             }
35             System.out.println("工人" + name + ",工作完毕");
36             downLatch.countDown();
37         }
38     }
39 
40     static class Boss implements Runnable{
41 
42         @Override
43         public void run() {
44             try {
45                 downLatch.await();
46             } catch (InterruptedException e) {
47                 e.printStackTrace();
48             }
49             System.out.println("Boss 检查工作");
50         }
51     }
52 }
53 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。