`

实战Concurrent(5)

阅读更多

来自http://www.iteye.com/topic/363625

 

5、CountDownLatch

CountDownLatch是一个一次性的同步辅助工具,允许一个或多个线程一直等待,直到计数器值变为0。它有一个构造方法,设定计数器初始值,即在await()结束等待前需要调用多少次countDown()方法。CountDownLatch的计数器不能重置,所以说它是“一次性”的,如果需要重置计数器,可以使用CyclicBarrier。在运行环境检查的主类中,使用了CountDownLatch来等待所有验证结束,在各个并发验证的线程完成任务结束前都会调用countDown(),因为有3个并发的验证,所以将计数器设置为3。

 

最后将所有这些类整合起来,运行环境检查的主类如下。它会创建线程池服务和验证服务,先做一次验证(相当于是对系统做次初始化),随后并发3个验证请求。系统运行完毕会显示实际执行的节点验证次数和执行时间。如果是顺序执行,验证次数应该是13*4=52,但实际的验证次数会少于这个数字(我这里最近一次执行了33次验证),因为如果同时有两个线程要验证同一节点时只会做一次验证。关于时间,如果是顺序执行,52次验证每次等待500ms,那么验证所耗费的时间应该是26000ms,使用了多线程后的实际耗时远小于该数字(最近一次执行耗时4031ms)。

Java代码 
  1. package  service.mock;  
  2.   
  3. import  java.util.ArrayList;  
  4. import  java.util.List;  
  5. import  java.util.concurrent.CountDownLatch;  
  6.   
  7. import  service.Node;  
  8. import  service.ThreadPoolService;  
  9. import  service.ValidationService;  
  10.   
  11. /**  
  12.  * 模拟执行这个环境的验证  
  13.  *   
  14.  * @author DigitalSonic  
  15.  */   
  16. public   class  ValidationStarter  implements  Runnable {  
  17.     private  List<String>      entries;  
  18.     private  ValidationService validationService;  
  19.     private  CountDownLatch    signal;  
  20.   
  21.     public  ValidationStarter(List<String> entries, ValidationService validationService,  
  22.             CountDownLatch signal) {  
  23.         this .entries = entries;  
  24.         this .validationService = validationService;  
  25.         this .signal = signal;  
  26.     }  
  27.   
  28.     /**  
  29.      * 线程池大小为10,初始化执行一次,随后并发三个验证  
  30.      */   
  31.     public   static   void  main(String[] args) {  
  32.         ThreadPoolService threadPoolService = new  ThreadPoolService( 10 );  
  33.         ValidationService validationService = new  ValidationService(threadPoolService);  
  34.         List<String> entries = new  ArrayList<String>();  
  35.         CountDownLatch signal = new  CountDownLatch( 3 );  
  36.         long  start;  
  37.         long  stop;  
  38.   
  39.         for  (Node node : MockNodeValidator.ENTRIES) {  
  40.             entries.add(node.getWsdl());  
  41.         }  
  42.   
  43.         start = System.currentTimeMillis();  
  44.   
  45.         validationService.validate(entries);  
  46.         threadPoolService.execute(new  ValidationStarter(entries, validationService, signal));  
  47.         threadPoolService.execute(new  ValidationStarter(entries, validationService, signal));  
  48.         threadPoolService.execute(new  ValidationStarter(entries, validationService, signal));  
  49.   
  50.         try  {  
  51.             signal.await();  
  52.         } catch  (InterruptedException e) {  
  53.             e.printStackTrace();  
  54.         }  
  55.   
  56.         stop = System.currentTimeMillis();  
  57.         threadPoolService.destoryExecutorService(1000 );  
  58.         System.out.println("实际执行验证次数: "  + MockNodeValidator.getCount());  
  59.         System.out.println("实际执行时间: "  + (stop - start) +  "ms" );  
  60.     }  
  61.   
  62.     @Override   
  63.     public   void  run() {  
  64.         validationService.validate(entries);  
  65.         signal.countDown();  
  66.     }  
  67.   
  68. }  
   

=================================我是分割线==============================

 

本文没有覆盖java.util.concurrent中的所有内容,只是挑选一些比较常用的东西,想要获得更多详细信息请阅读JavaDoc。自打有了“轮子”理论,重复造大轮子的情况的确少了,但还是有人会做些小轮子,例如编写多线程程序时用到的小工具(线程池、锁等等),如果可以,请让自己再“懒惰”一点吧~

分享到:
评论

相关推荐

    实战Concurrent

    "实战Concurrent"这一主题主要聚焦于Java中的并发编程,它涉及到多线程、并发容器、同步机制以及性能优化等多个方面。通过深入理解并实践这些概念,开发者可以更好地设计和实现能够充分利用现代多核处理器能力的应用...

    实战Concurrent-BlockQueue

    《实战Concurrent-BlockQueue》 在Java并发编程领域,`Concurrent-BlockQueue`是一个重要的数据结构,它结合了线程安全与高效性能。本文将深入探讨`ConcurrentLinkedQueue`、`ArrayBlockingQueue`以及`...

    Doug Lea, Concurrent Programming in Java Design Principles and Patterns

    5. **性能优化**:书中还讨论了如何在并发环境中进行性能调优,包括线程池的配置、并发级别的选择以及如何有效地利用硬件资源。 6. **并发编程的挑战**:书中分析了在分布式系统中遇到的挑战,如网络延迟、不可预知...

    使用Java并发编程Concurrent Programming Using Java

    Java平台提供了丰富的API支持并发编程,如`java.util.concurrent`包下的各种类和接口,这些工具可以帮助开发者更高效地管理多线程环境下的任务调度和数据共享问题。 ### Java并发编程基础 #### 1. 多线程基础 - **...

    java并发编程实战源码-concurrent-programming:《Java并发编程实战》源码整理

    5. **线程安全的数据结构**:Java的`java.util.concurrent`包提供了线程安全的集合,如`ConcurrentHashMap`、`CopyOnWriteArrayList`等,它们内部实现了高效的并发控制,避免了同步带来的性能损失。 6. **线程池**...

    Java 并发编程实战.pdf

    此外,该书可能会对Java中一些新的并发API进行探讨,如java.util.concurrent包下的工具类和接口,例如Executor框架、Future、CompletableFuture、ConcurrentHashMap、Semaphore等。这些工具类和接口在构建大规模并发...

    concurrent-programming:《实战java高并发程序设计》源码整理

    《实战java高并发程序设计》源码整理联系作者十三的java的学习交流QQ群: 881582471 , 658365129(已满)相关文章书籍封面目录第1章走入并行世界1.1何去何从的并行计算1.1.1忘掉那该死的并行1.1.2可怕的现实:摩尔...

    (PDF带目录)《Java 并发编程实战》,java并发实战,并发

    5. **原子变量**:Java提供了一组`Atomic`类,如`AtomicInteger`、`AtomicLong`等,它们提供了原子性的读写操作,无需显式同步就能保证线程安全。 6. **线程池**:线程池是并发编程中常用的模式,它通过复用线程和...

    《java 并发编程实战高清PDF版》

    《Java并发编程实战》是一本深入探讨Java平台并发编程的权威指南。这本书旨在帮助开发者理解和掌握在Java环境中创建高效、可扩展且可靠的多线程应用程序的关键技术和实践。它涵盖了从基本概念到高级主题的广泛内容,...

    Java并发编程:设计原则与模式(Concurrent.Programming.in.Java)(中英版)

    这本书不仅提供了丰富的理论知识,还介绍了实战中的设计原则和模式,对于Java开发者来说是不可或缺的参考资源。 在Java并发编程领域,理解设计原则至关重要,因为它们指导我们编写高效、安全且可维护的多线程代码。...

    java concurrent in practive

    《Java并发编程实战》还会讨论`java.util.concurrent`包中的高级并发工具,如`ExecutorService`和`Future`,它们可以方便地管理和控制线程池,提高系统的并行处理能力。`CountDownLatch`、`CyclicBarrier`和`...

    Concurrent Programming on Windows

    五、实战技巧与理论知识的完美结合 Steve Teixeira,微软Parallel Computing Platform部门的产品单元经理,对本书给予了高度评价。他认为本书既全面覆盖了Windows平台上的并发编程,又实用地介绍了可以直接应用于...

    python爬虫项目实战

    6. **多线程与异步IO**:通过`concurrent.futures`或者`asyncio`库实现多线程或异步爬取,提升爬虫效率。 7. **Scrapy框架应用**:当项目规模扩大时,使用Scrapy框架可以更好地组织代码,处理复杂的爬虫逻辑,如...

    实战Java高并发程序设计(高清版)

    4. **并发工具类**:Java并发包(java.util.concurrent)中包含了很多实用的工具类,如`Future`、`CompletableFuture`、`Semaphore`等,这些工具可以帮助开发者更好地管理并发任务。 5. **J.U.C框架**:Java并发 ...

    Java并发编程实战

    5.1.2 迭代器与Concurrent-ModificationException 5.1.3 隐藏迭代器 5.2 并发容器 5.2.1 ConcurrentHashMap 5.2.2 额外的原子Map操作 5.2.3 CopyOnWriteArrayList 5.3 阻塞队列和生产者-消费者模式 5.3.1 ...

    java并发编程实战高清版pdf

    5. **原子变量**:`java.util.concurrent.atomic`包中的原子变量类,如`AtomicInteger`、`AtomicLong`,提供了在不使用锁的情况下进行线程安全的操作。 6. **并发工具类**:`java.util.concurrent`包提供了许多实用...

    c#多线程编程实战(原书第二版)源码

    《C#多线程编程实战(原书第二版)源码》是一本深入探讨C#中多线程技术的专业书籍,其源码提供了丰富的实践示例,帮助读者掌握并发编程的核心概念和技术。在C#中,多线程是实现高性能、响应式应用程序的关键组成部分...

Global site tag (gtag.js) - Google Analytics