CyclicBarrier、CountDownLatch与Semaphore的小记
CyclicBarrier:
适合的业务场景,比如
1)、,现有一大任务,需要得到全年的统计数据的,这个工作量是巨大的,那么可以将其分割为12个月的子任务,各个子任务相互独立,当所有子任务完成了,则就可以进行全年统计了,这样大大提升了统计效率。
2)、大家一起去郊游,由于大家住的地方比较分散,故需要一个集合点之后一起出发,这样大家才能玩得开心嘛。
。。。。等等
就是当有一个大任务时,需要分配多个子任务去执行,只有当所有的子任务都执行完成后,才能执行主任务。
//阻塞等待
public int await()
CountDownLatch:
适合的业务场景,比如
1)、运动会中赛跑项目,之后所有的赛跑运动员准备好了,此时裁判才能宣布该赛跑项目正式开始,裁判才能打出发信枪;当参与此次赛跑项目的所有的运动员都跑完了,此次赛跑项目才能算结束,才能统计出比赛名次。
。。。。等等
就是所有的准备好了,才能开始;或者是所有的都结束了,才能算结束。
//阻塞等待,直到计数器清零
public void await() //阻塞等待,直到等待到最长时间,当等待时间超过设置时间时,计数器还没有清零,则返回false,否则返回true
public boolean await(long timeout, TimeUnit unit) //计数器减一,当计数器清零时,await的线程会被唤醒,线程继续执行
public void countDown() //获取当前计数器的大小
public long getCount()
Semaphore:
适合的业务场景,比如
1)、当有10个人去上茅厕,但是只有5个坑,即只能同时5个人使用,只有当一个人不使用坑了,另一个人才能使用该空闲的坑,一直维持着只能同时5个人使用。
2)、当停车场来了100辆车时,但是只有30个停车位,即只能同时提供30个车辆停放,只有当一辆车开走了,另一辆车才能进入该空闲的停车位,一直维持着只能同时提供30个停车位。
。。。。等等
就是同时只能提供有限的,走一个才能进一个。
//申请获取许可,当没有剩余的许可时,则被阻塞
public void acquire() //释放一个许可
public void release()
总结:
CountDownLatch是等待一组线程执行完毕后才能继续执行 CyclicBarrier是能让一组线程达到一个同步点时被阻塞,直到最后一个线程达到,阻塞才会消失,其是可以循环使用的 Semaphore是只允许一定数量的线程同时执行
CyclicBarrier、CountDownLatch与Semaphore的小记的更多相关文章
- java并发之CountDownLatch、Semaphore和CyclicBarrier
		
JAVA并发包中有三个类用于同步一批线程的行为,分别是CountDownLatch.Semaphore和CyclicBarrier. CountDownLatch Java之CountDownLatc ...
 - 转发---[沧海拾遗]java并发之CountDownLatch、Semaphore和CyclicBarrier
		
JAVA并发包中有三个类用于同步一批线程的行为,分别是CountDownLatch.Semaphore和CyclicBarrier. CountDownLatch CountDownLatch是一个计 ...
 - 30行自己写并发工具类(Semaphore, CyclicBarrier, CountDownLatch)是什么体验?
		
30行自己写并发工具类(Semaphore, CyclicBarrier, CountDownLatch)是什么体验? 前言 在本篇文章当中首先给大家介绍三个工具Semaphore, CyclicBa ...
 - Java多线程20:多线程下的其他组件之CountDownLatch、Semaphore、Exchanger
		
前言 在多线程环境下,JDK给开发者提供了许多的组件供用户使用(主要在java.util.concurrent下),使得用户不需要再去关心在具体场景下要如何写出同时兼顾线程安全性与高效率的代码.之前讲 ...
 - Java并发(6)- CountDownLatch、Semaphore与AQS
		
引言 上一篇文章中详细分析了基于AQS的ReentrantLock原理,ReentrantLock通过AQS中的state变量0和1之间的转换代表了独占锁.那么可以思考一下,当state变量大于1时代 ...
 - J.U.C-三剑客[semaphore\CyclicBarrier\CountDownLatch]
		
一.semaphore信号量,底层也是基于AQS 使用: /** * 可以理解为控制某个资源最多有多少个线程同时执行,(比如洗手间,并行与排队) * 如果满了只能等待直到其它资源释放(可以理解为并发量 ...
 - java线程并发工具类CyclicBarrier、CountDownLatch及Semaphore
		
一.CyclicBarrier (原文链接:http://www.studyshare.cn/blog-front/blog/index ) 1.定义 CyclicBarrier是线程并发工具类之 ...
 - java.util.concurrent常用类(CountDownLatch,Semaphore,CyclicBarrier,Future)
		
CyclicBarrier CyclicBarrier是用来一个关卡来阻挡住所有线程,等所有线程全部执行到关卡处时,再统一执行下一步操作.假设一个场景:每个线程代表一个跑步运动员,当运动员都准备好后, ...
 - AQS之CountDownLatch、Semaphore、CyclicBarrier
		
CountDownLatch A synchronization aid that allows one or more threads to wait until a set of operatio ...
 
随机推荐
- 制作OpenStack用的RHEL7系统镜像
			
制作OpenStack使用的RHEL7系统镜像,并进行相关设置,安装XRDP以进行远程访问. 1.在KVM中安装RHEL7.2客户机: 2.设置网卡为dhcp并onboot=yes,使得虚拟机能自动获 ...
 - Javascript null和undefined
			
Javascript的数据类型包括数字.字符串.布尔值.null.undefined和对象.其中null和undefined是两种特殊的原始类型,很容易混淆.今天就来剖析一下null和undefine ...
 - 寻找“水王”--c++
			
一.题目与设计思路 三人行设计了一个灌水论坛.信息学院的学生都喜欢在上面交流灌水,传说在论坛上有一个“水王”,他不但喜欢发帖,还会回复其他ID发的每个帖子.坊间风闻该“水王”发帖数目超过了帖子数目的一 ...
 - Chapter 3  Discovering Classes and Object
			
Chatper 3 Discovering Classes and Object Exercises: 1.What is a class? A class is a template for man ...
 - 代码复用 -- 深入了解javascript
			
/* 代码复用 */ /* 一.避免 */ /* 模式1:默认模式 */ function Parent() { this.name = "123"; } Parent.proto ...
 - 设计模式之观察者模式(Observer)
			
观察者模式原理:当有新的消息产生时发送给观察者,和中介者模式的不同地方是中介者模式强调中介的作用以及中介双方的交互,观察者模式是主动调用观察者成员函数进行消息发送. 代码如下: #include &l ...
 - Maven搭建webService (三) 创建客户端---使用Apache CXF方式实现
			
package test; import net.cc.web.server.HelloWorld; import org.apache.cxf.jaxws.JaxWsProxyFactoryBean ...
 - Lessons learned from manually classifying CIFAR-10
			
Lessons learned from manually classifying CIFAR-10 Apr 27, 2011 CIFAR-10 Note, this post is from 201 ...
 - Kali-linux安装之后的简单设置
			
1.更新软件源:修改sources.list文件:leafpad /etc/apt/sources.list然后选择添加以下适合自己较快的源(可自由选择,不一定要全部): #官方源deb http:/ ...
 - Samy XSS Worm之源码讲解
			
说到Web安全和XSS跨站脚本技术,几乎所有的书都会提到Samy Worm,这是在2005年感染了mySpace社交网络上百万用户的蠕虫.正如Morris蠕虫是互联网第一个蠕虫, Samy Worm则 ...