爱睡觉的程序员

  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  5 随笔 :: 0 文章 :: 0 评论 :: 0 Trackbacks

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 
posted on 2015-02-26 15:09 polang 阅读(113) 评论(0)  编辑  收藏

只有注册用户登录后才能发表评论。


网站导航: