java多线程等待协调工作:CountDownLatch类的高级应用
一:说明
基本上对于线程初步了解的人,都是使用synchronized来同步线程的,也确实,它也是可以满足一些常用的问题。那么我们来说一些它不能解决的问题(其实是不怎么好解决的问题,并不是真的不能解决)
1.1:场景一
问题:
在一场运动会上,有10个运动员,只有当10个运动员都准备完毕后,所有人才能一起跑,否则就算前面的运动员在几天前都做好准备了,只要最后一个运动员没有做好准备,那所有的人都不能跑,有失公平嘛!
常规的解决方法
定义一个计数器,并且对它的操作进行同步,当每有一个准备完毕后,增加这个计数器的准备好的数量,当达到10个的时候,全部一起运行,那么大概的代码是这样子的,程序要定义一个死循环,只有当所有的条件满足的时候,才能往下走,否则就一直循环。
1.2:场景二:多线程下载文件,我们使用它来作为例子
为了提高下载效率,充分利用网络资源,决定使用多线程来下载一个文件,那么每一个线程分别下载一小段文件,当所有的文件下载完之后,对所有的文件进行合并,那就得到完整的文件了。
理论上来说代码是这样子的(理论上,实际上是错误的)
public static void go(){
System.out.println("开始下载文件,开启10个线程下载");
for(int i = 0 ; i < 10 ; i ++){
new Thread(){
public void run(){
System.out.println("文件下载完成");
}
}.start();
}
//开始合并文件
System.out.println("所有文件下载完成,开始合并文件");
}
上面的代码开启了10个线程去下载文件,下载完之后,执行合并文件的方法,但是由于多线程,合并文件的时候,线程肯定是没有执行完成的。
要怎么办呢?这个时候命名用synchronized肯定是没用的,synchronized只是使得同一时间只有一个线程通过
二:CountDownLatch使用所有的线程等待。
CountDownLatch这个类,可以使得所有的线程,全部停在那一个位置,达到指定的条件的时候,才可以运行。先给出代码
public static void main(String[] args) throws Exception {
//这里的构造方法参数是指需要达到完成的数量个数
final CountDownLatch cd = new CountDownLatch(10); for(int i = 0 ; i < 10 ; i ++){
new Thread(){
public void run(){
System.out.println("文件下载完成");
//还记得之前构造方法的参数吗,10,每调用一个countDown()方法,都会使得这个数值减1
cd.countDown();
}
}.start();
} //这个方法,会使得所有的线程暂停,只有当cd构造方法里面的值为0的时候,才能走通,调用一个countDown()方法,都会使得这个数值减1
cd.await();
//或者使用这个方法,这个方法也会等待数值到0才会往下面走,但是如果达到指定的时间,还没有达到0,它也会走过
// cd.await(1000, TimeUnit.MINUTES);
//开始合并文件
System.out.println("所有文件下载完成,开始合并文件"); }
执行结果是这样的
文件下载完成
文件下载完成
文件下载完成
文件下载完成
文件下载完成
文件下载完成
文件下载完成
文件下载完成
文件下载完成
文件下载完成
所有文件下载完成,开始合并文件
这样就满足条件啦
java多线程等待协调工作:CountDownLatch类的高级应用的更多相关文章
- java多线程并发去调用一个类的静态方法安全性探讨
java多线程并发去调用一个类的静态方法安全性探讨 转自:http://blog.csdn.net/weibin_6388/article/details/50750035 这篇文章主要讲多线程对 ...
- java多线程10:并发工具类CountDownLatch、CyclicBarrier和Semaphore
在JDK的并发包(java.util.concurrent下)中给开发者提供了几个非常有用的并发工具类,让用户不需要再去关心如何在并发场景下写出同时兼顾线程安全性与高效率的代码. 本文分别介绍Coun ...
- Java多线程系列——线程阻塞工具类LockSupport
简述 LockSupport 是一个非常方便实用的线程阻塞工具,它可以在线程内任意位置让线程阻塞. 和 Thread.suspend()相比,它弥补了由于 resume()在前发生,导致线程无法继续执 ...
- 【Java多线程系列五】列表类
一些列表类及其特性 类 线程安全 Iterator 特性 说明 Vector 是 fail-fast 内部方法用synchronized修饰,因此执行效率较低 1. 线程安全的列表类并不意味着调用它 ...
- JAVA多线程提高五:原子性操作类的应用
当程序更新一个变量时,如果多线程同时更新这个变量,可能得到期望之外的值,比如变量i=1,A线程更新i+1,B线程也更新i+1,经过两个线程操作之后可能i不等于3,而是等于2.因为A和B线程在更新变量i ...
- java多线程无锁和工具类
1 无锁 (1) cas (compare and swap) 设置值的时候,会比较当前值和当时拿到的值是否相同,如果相同则设值,不同则拿新值重复过程:注意,在设置值的时候,取值+比较+设值 是一条c ...
- Java多线程_同步工具CountDownLatch
概念:CountDownLatch是多线程里面一个类似于计数器的高级同步工具,它的初始值代表线程的数量,当一个线程完成了任务后,CountDownLatch的值就减1,当值为0的时候,代表所有线程完成 ...
- JAVA多线程学习九-原子性操作类的应用
当程序更新一个变量时,如果多线程同时更新这个变量,可能得到期望之外的值,比如变量i=1,A线程更新i+1,B线程也更新i+1,经过两个线程操作之后可能i不等于3,而是等于2.因为A和B线程在更新变量i ...
- java多线程(一)之继承Thread类
一.概述 进程:正在执行的应用程序 线程:进程的执行单元,执行路径 单线程:一个应用程序只有一条执行路径 多线程:一个应用程序有多条执行路径 二.两种实现方式, 下面为第一种方式: 继承Thread类 ...
随机推荐
- canvas生成图片并保存到本地文件夹主要代码
js var url = canvas.toDataURL();//把canvas中的图片变成data:image C# string filepath = ""; string ...
- MVC自定义分页(附表跳转页Loading提示)
之前我发表了一篇MVC无刷新分页的文章,里面用的是MvcPager控件,但是那个受那个控件限制,传值只能用PagedList,各方面都受到了限制,自由度不够高,现在还是做MVC无刷新分页,但是想直接用 ...
- android——handler机制原理
在android版本4.0及之后的版本中多线程有明确的分工,子线程可以写所有耗时的代码(数据库.蓝牙.网络服务),但是绝对不能碰UI,想碰UI跟着主线程走,那么我们如何才能让主线程知道我们要对 UI进 ...
- Oracle like查询
查询方式:LIKE '%xx%' 普通: SELECT * FROM TABLE T WHERE T.COLUNM LIKE '%xx%' 优化:使用 INSTR SELECT * FROM TABL ...
- Sort简单排序
List<T> 类型排序: public List<ProductionMaterialModel> OrderBybom(List<ProductionMaterial ...
- 循序渐进做项目系列(4)迷你QQ篇(2)——视频聊天!(附源码)
一·效果展示 源码派送:MiniQQ1.1 文字聊天的实现参见:循序渐进做项目系列(3):迷你QQ篇(1)——实现客户端互相聊天 二·服务端设计 对于实现视频聊天而言,服务端最核心的工作就是要构造多媒 ...
- 最流行的编程语言 JavaScript 能做什么?
此文转载oschina文章 首先很遗憾的一点是,“PHP虽然是最好的语言”,但是它不是最流行的语言. 同时对不起的还有刚刚在4月TIOBE编程语言排行榜上上榜的各个语言: 你们都很棒,但是你们都担当不 ...
- iconfont的蜕化操作
很多国外的网站,访问的时候可以看到,页面先是大面积白一下,然后恢复正常.原因是网页上用到了 webfont,这些页面很多情况都是直接引用 google 的 webfont 地址,中华大局域网下,由于网 ...
- 开始研究web,mark一下
之前想要搞引擎,经过思考之后,定位为webgl方面的引擎,这个决定早就做了,只是没有写下来 做了一些调研之后,确定使用babylon.js 和typescript 和c# 来开发 Babylo ...
- 使用GDB调试Go语言
用Go语言已经有一段时间了,总结一下如何用GDB来调试它! ps:网上有很多文章都有描述,但是都不是很全面,这里将那些方法汇总一下 GDB简介 GDB是GNU开源组织发布的⼀一个强⼤大的UNIX下的 ...