CountDownLatch分析
1 什么是CountDownLatch呢?
先看看官网的定义 :一种同步帮助,允许一个或多个线程等待,直到在其他线程中执行的一组操作完成。
现在由我来解释什么是CountDownLatch吧;比如说我当前存在4个线程,其中一个是主线程,3个普通线程。我们要做一个项目,希望线程A负责自动登陆,线程B负责记录登陆日志,线程C负责加载页面信息;而我的主线程则只需要在三者完成后才启动,执行其他的应用;
CountDownLatch(int count) 构造一个用给定计数初始化的 CountDownLatch。
这是CountDownLatch的构造器,count为当前线程的数量,比如上述我们可以传入一个4;
public void await()throws InterruptedException
public boolean await(long timeout,TimeUnit unit) throws InterruptedException
public void countDown()
await()方法有两个,其中一个指定了超时时间。调用此方法的线程会被挂起,而调用countDown()方法的线程,每一次的调用都会使得之前构造器中的count的值减去1;知道为0时,调用过await()方法的线程会被唤醒,开始执行。
请看如下的代码:
package com.net; import java.util.Random;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors; public class CountDownLatchDemo { // 1 创建CountDownLatch对象
private CountDownLatch cdl = new CountDownLatch(2);
// 1.1 生成随机数对象
private Random rnd = new Random(); // 2 第一个线程对象
class FirstTask implements Runnable {
private String id; public FirstTask(String id) {
this.id = id;
} @Override
public void run() {
System.out.println("Thread " + id + " is start");
try {
// 休眠几秒
Thread.sleep(rnd.nextInt(1000));
} catch (Exception e) {
e.printStackTrace();
}
System.out.println("Thread " + id + " is over");
// 线程执行完毕调用一次countDown()方法
cdl.countDown(); }
} // 3 第二个线程对象
class SecondTask implements Runnable {
private String id; public SecondTask(String id) {
this.id = id;
} @Override
public void run() {
try {
// 调用await()方法,使得当前线程挂起
cdl.await();
} catch (InterruptedException e) { e.printStackTrace();
}
//当当前线程被唤醒之后才开始执行
System.out.println("----------Thread " + id + " is start");
try {
Thread.sleep(rnd.nextInt(1000));
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("----------Thread " + id + " is over");
} }
public static void main(String[] args) {
// 创建一个线程池
ExecutorService es = Executors.newCachedThreadPool();
CountDownLatchDemo cdld = new CountDownLatchDemo();
//将c,d交给任务2,说明会被率先挂起
es.submit(cdld.new SecondTask("c"));
es.submit(cdld.new SecondTask("d"));
//将a,b交给任务1开始执行
es.submit(cdld.new FirstTask("a"));
es.submit(cdld.new FirstTask("b"));
es.shutdown();
}
}

CountDownLatch分析的更多相关文章
- 【Java并发编程实战】-----“J.U.C”:CountDownlatch
		
上篇博文([Java并发编程实战]-----"J.U.C":CyclicBarrier)LZ介绍了CyclicBarrier.CyclicBarrier所描述的是"允许一 ...
 - java源码-Semaphore源码分析
		
Semaphore内部Sync对象同样也是继承AQS,跟Reentrant一样有公平锁跟非公平锁区分,但是Semaphore是基于共享锁开发,Reentrant是基于独占锁开发.主要就是初始化Sema ...
 - java 并发(五)---AbstractQueuedSynchronizer(3)
		
文章代码分析和部分图片来自参考文章 问题 : CountDownLatch 和 CyclicBarrier 的区别 认识 CountDownLatch 分析这个类,首先了解一下它所可以 ...
 - 【JUC】JDK1.8源码分析之CountDownLatch(五)
		
一.前言 分析完了CyclicBarrier后,下面分析CountDownLatch,CountDownLatch用于同步一个或多个任务,强制他们等待由其他任务执行的一组操作完成.CountDownL ...
 - Java 线程同步组件 CountDownLatch 与 CyclicBarrier 原理分析
		
1.简介 在分析完AbstractQueuedSynchronizer(以下简称 AQS)和ReentrantLock的原理后,本文将分析 java.util.concurrent 包下的两个线程同步 ...
 - 并发编程(七)——AbstractQueuedSynchronizer 之 CountDownLatch、CyclicBarrier、Semaphore  源码分析
		
这篇,我们的关注点是 AQS 最后的部分,共享模式的使用.本文先用 CountDownLatch 将共享模式说清楚,然后顺着把其他 AQS 相关的类 CyclicBarrier.Semaphore 的 ...
 - Java并发编程笔记之 CountDownLatch闭锁的源码分析
		
JUC 中倒数计数器 CountDownLatch 的使用与原理分析,当需要等待多个线程执行完毕后在做一件事情时候 CountDownLatch 是比调用线程的 join 方法更好的选择,CountD ...
 - Java - "JUC" CountDownLatch源码分析
		
Java多线程系列--“JUC锁”09之 CountDownLatch原理和示例 CountDownLatch简介 CountDownLatch是一个同步辅助类,在完成一组正在其他线程中执行的操作之前 ...
 - CountDownLatch使用场景及分析
		
JDk1.5提供了一个非常有用的包,Concurrent包,这个包主要用来操作一些并发操作,提供一些并发类,可以方便在项目当中傻瓜式应用. JDK1.5以前,使用并发操作,都是通过Thread,Run ...
 
随机推荐
- 实用篇:说说我在JavaScript项目中使用的工具类
			
在JavaScript的开发中,我们都会写一些工具类来帮我们简化一些业务操作的逻辑,一下就貼几个我在项目开发过程中常用的工具类.表达能力有限,各位看官还是看源码吧. 一.日期处理工具类. /** * ...
 - 模块化(CommonJs、AMD、CMD、UMD)发展历史与优缺点
			
全文主要整理自摘自<Webpack中文指南>(好文,建议直接去看,以下仅对该系列文章中的<历史发展>篇幅进行备份——也整理了点其他内容) 模块化 模块化是老生常谈了,这里不做阐 ...
 - Google员工自述:在哈佛教书和在Google工作的差别
			
感谢伯乐在线的投递编者按:2003年到2010年期间,原文作者Matt Welsh 是哈佛大学工程和应用科学学院的计算机科学系教授.2010年加入Google,是一名高级工程师.他当前的工作重点是广域 ...
 - php执行外部命令函数:exec()、passthru()、system()、shell_exec()对比
			
PHP提供了4种方法执行系统外部命令:exec().passthru().system().shell_exec(),下面分别介绍: 1.exec 原型:string exec ( string $c ...
 - JAVAScript中DOM与BOM的差异分析
			
JAVAScript 有三部分构成,ECMAScript,DOM和BOM,根据浏览器的不同,具体的表现形式也不尽相同.我们今天来谈一谈DOM和BOM这俩者之间的差异. 用百科上的来说: 1. DOM是 ...
 - codevs1997 守卫者的挑战
			
题目描述 Description 打开了黑魔法师Vani的大门,队员们在迷宫般的路上漫无目的地搜寻着关押applepi的监狱的所在地.突 然,眼前一道亮光闪过.“我,Nizem,是黑魔法圣殿的守卫者. ...
 - WCF REST开启Cors 解决 No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost' is therefore not allowed access. The response had HTTP status code 405.
			
现象: 编写了REST接口: [ServiceContract] public interface IService1 { [OperationContract] [WebInvoke(UriTemp ...
 - 爬虫第一篇:爬虫详解之urllib.request模块
			
我将urllib.request 的GET请求和POST请求两种方法做了总结 GET请求 GET请求爬取: import urllib.request import urllib.parse head ...
 - vuex使用mapActions报错解决办法
			
先贴上报错: vuex2增加了mapGetters和mapActions的方法,借助stage2的Object Rest Operator 所在通过 methods:{ ...mapActions([ ...
 - Appium-xpath详解
			
一.xpath简介 XPath就是XML 路径,练习XPath的使用可以直接使用火狐浏览器 火狐浏览器下载 free bug和free path两个插件. 手机xpath可以自己写,路径关键字选cla ...