文档章节

java并发包里的CountDownLatch的用法

汪林
 汪林
发布于 2014/06/18 10:47
字数 456
阅读 1802
收藏 6

CountDownLatch

官方的解释为:一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待。

我们现在就把它理解为倒数计数器,什么是倒数计数器呢,通俗的理解就是这个计数器事先有一个初始计数,在这个计数减到0之前,所有的线程等待。

笔者今天早晨又看一则新闻说的高考“枪手”,看来每逢高考,“枪手”必火。那我们来模拟一下“枪手”的招募过程。假如我需要10个“枪手”,招募者一声令下,开始招募,我们开始在大学里张贴“招兵启示”,等到这10个“枪手”都到齐,开动大巴车把他们送到“战场”。

这里笔者需要大家注意两个地方:第一,招募人一声令下,开始招募。第一,只有等到10个“枪手“都到了才能开动大巴。

package com.core.countDownLatch;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class CountDownLatchTest {
    
    public static void main(String[] args) throws InterruptedException {
        
        //倒数计数器
        final CountDownLatch begin = new CountDownLatch(1);
        
        //倒数计数器
        final CountDownLatch end = new CountDownLatch(10);
        
        //十名枪手
        ExecutorService execu = Executors.newFixedThreadPool(10);
        
        //模拟招募10名枪手到齐后开动大巴,送往“战场”
        for(int i=0;i<10;i++){
            
            final int NO = i+1;
            
            Runnable r = new Runnable() {
                
                @Override
                public void run() {
                    
                    try {
                        
                        //等待招募者下令招募
                        begin.await();
                        
                        Thread.sleep((long) (Math.random()*10000));
                        
                        System.out.println("枪手:"+NO+"到了");
                        
                    } catch (InterruptedException e) {
                        
                        e.printStackTrace();
                        
                    }finally{
                        
                        //每到达一个枪手,计数器减1
                        end.countDown();
                    }
                }
            };
            
            execu.submit(r);
        }
        
        //begin倒数计数器减1为0,则开始下招募令,一声令下
        begin.countDown();
        
        System.out.println("开始招募。。。。");
        
        //等待所有的枪手到达
        end.await();
        
        //所有枪手到达
        System.out.println("所有枪手到达,开动大巴,送往目的地。。。。");
        
        execu.shutdown();
        
    
    }
}


© 著作权归作者所有

共有 人打赏支持
汪林
粉丝 7
博文 19
码字总数 8847
作品 0
海淀
程序员
Java中高级面试必问之多线程TOP50(含答案)

以下为大家整理了今年一线大厂面试被问频率较高的多线程面试题,由于本人的见识局限性,所以可能不是很全面,也欢迎大家在后面留言补充,谢谢。 1、什么是线程? 2、什么是线程安全和线程不安...

老道士
08/28
0
0
java多线程系列:通过对战游戏学习CyclicBarrier

CyclicBarrier是java.util.concurrent包下面的一个工具类,字面意思是可循环使用(Cyclic)的屏障(Barrier),通过它可以实现让一组线程到达一个屏障(也可以叫同步点)时被阻塞,直到最后一...

huangzd
01/06
0
0
Java并发编程:CountDownLatch、CyclicBarrier和Semaphore

Java并发编程:CountDownLatch、CyclicBarrier和Semaphore   在java 1.5中,提供了一些非常有用的辅助类来帮助我们进行并发编程,比如CountDownLatch,CyclicBarrier和Semaphore,今天我们...

明舞
2015/09/01
0
0
JUC锁框架——CountDownLatch

CountDownLatch简单介绍 CountDownLatch是同步工具类之一,可以指定一个计数值,在并发环境下由线程进行减1操作,当计数值变为0之后,被await方法阻塞的线程将会唤醒,实现线程间的同步。 Co...

长头发-dawn
09/13
0
0
【Java并发专题】27篇文章详细总结Java并发基础知识

努力的意义,就是,在以后的日子里,放眼望去全是自己喜欢的人和事! github:https://github.com/CL0610/Java-concurrency,欢迎题issue和Pull request。所有的文档都是自己亲自码的,如果觉...

你听___
05/06
0
0

没有更多内容

加载失败,请刷新页面

加载更多

可爱的python测试开发库(python测试开发工具库汇总)

欢迎转载,转载请注明来源: github地址 谢谢点赞 本文地址 相关书籍下载 测试开发 Web UI测试自动化 splinter - web UI测试工具,基于selnium封装。 链接 selenium - web UI自动化测试。 链...

python测试开发人工智能安全
51分钟前
2
0
Shiro | 实现权限验证完整版

写在前面的话 提及权限,就会想到安全,是一个十分棘手的话题。这里只是作为学校Shiro的一个记录,而不是,权限就应该这样设计之类的。 Shiro框架 1、Shiro是基于Apache开源的强大灵活的开源...

冯文议
今天
1
0
linux 系统的运行级别

运行级别 运行级别 | 含义 0 关机 1 单用户模式,可以想象为windows 的安全模式,主要用于修复系统 2 不完全的命令模式,不含NFS服务 3 完全的命令行模式,就是标准的字符界面 4 系统保留 5 ...

Linux学习笔记
今天
2
0
学习设计模式——命令模式

任何模式的出现,都是为了解决一些特定的场景的耦合问题,以达到对修改封闭,对扩展开放的效果。命令模式也不例外: 命令模式是为了解决命令的请求者和命令的实现者之间的耦合关系。 解决了这...

江左煤郎
今天
3
0
字典树收集(非线程安全,后续做线程安全改进)

将500W个单词放进一个数据结构进行存储,然后进行快速比对,判断一个单词是不是这个500W单词之中的;来了一个单词前缀,给出500w个单词中有多少个单词是该前缀. 1、这个需求首先需要设计好数据结...

算法之名
昨天
15
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部