Latch设计模式
import java.util.concurrent.ThreadLocalRandom;
import java.util.concurrent.TimeUnit;
public class Test {
public static void main(String[] args){
// ProgrammerTravleTest.test();
ProgrammerTravleTest.test2();
}
}
/*
第23章 Latch 设计模式
若干线程并发执行某个特定的任务,然后等到所有的子任务都执行结束之后再统一汇总。
23.2 CountDownLatch程序实现
23.2.1 无限等待的Latch
*/
class WaitTimeoutException extends Exception{
public WaitTimeoutException(String msg) {
super(msg);
}
}
abstract class Latch{
protected int limit;
public Latch(int limit) {
this.limit = limit;
}
//该方法会使得当前线程一致等待
public abstract void await()throws InterruptedException;
//带超时功能的
public abstract void await(TimeUnit unit, long time) throws InterruptedException,WaitTimeoutException;
//当任务线程完成工作之后调用该方法使得计数器减一
public abstract void countDown();
//获取当前还有多少个线程没有完成任务
public abstract int getUnarrived();
}
//无限等待CountDownLatch实现
class CountDownLatch extends Latch{
public CountDownLatch(int limit) {
super(limit);
}
@Override
public void await() throws InterruptedException {
synchronized (this) {
while (limit > 0) {
this.wait();
}
}
}
/*
这个写法在写改写sysn时用过了。
*/
@Override
public void await(TimeUnit unit, long time) throws InterruptedException, WaitTimeoutException {
if (time < 0) {
throw new IllegalArgumentException("The time is invalid.");
}
long remainingNanos = unit.toNanos(time);
final long endNanos = System.nanoTime()+ remainingNanos;
synchronized (this) {
while (limit > 0) {
if (TimeUnit.NANOSECONDS.toMillis(remainingNanos) <= 0) {
throw new WaitTimeoutException("The wait time over specify time.");
}
this.wait(TimeUnit.NANOSECONDS.toMillis(remainingNanos));
remainingNanos=endNanos-System.nanoTime();
}
}
}
@Override
public void countDown() {
synchronized (this) {
if (limit <= 0) {
throw new IllegalArgumentException("all of task already arrived");
}
limit--;
this.notifyAll();
}
}
@Override
public int getUnarrived() {
return limit;
}
}
//程序测试齐心协力打开门阀
class ProgrammerTravle extends Thread{
private final Latch latch;
private final String programmer;
private final String transportation;
public ProgrammerTravle(Latch latch, String programmer, String transportation) {
this.latch = latch;
this.programmer = programmer;
this.transportation = transportation;
}
@Override
public void run() {
System.out.println(programmer+" start take the transportation["+transportation+"]");
try{
TimeUnit.SECONDS.sleep(ThreadLocalRandom.current().nextInt(10));
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(programmer+" arrived by "+transportation);
latch.countDown();
}
}
class ProgrammerTravleTest{
public static void test(){
Latch latch = new CountDownLatch(4);
new ProgrammerTravle(latch,"A","a").start();
new ProgrammerTravle(latch,"B","b").start();
new ProgrammerTravle(latch,"C","c").start();
new ProgrammerTravle(latch,"D","d").start();
try {
latch.await();
System.out.println("==all of programmer arrived==");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public static void test2(){
Latch latch = new CountDownLatch(4);
new ProgrammerTravle(latch,"A","a").start();
new ProgrammerTravle(latch,"B","b").start();
new ProgrammerTravle(latch,"C","c").start();
new ProgrammerTravle(latch,"D","d").start();
try {
latch.await(TimeUnit.SECONDS,5);
System.out.println("==all of programmer arrived==");
} catch (InterruptedException e) {
e.printStackTrace();
} catch (WaitTimeoutException e) {
e.printStackTrace();
}
}
}
《Java高并发编程详解》笔记
Latch设计模式的更多相关文章
- Android开发中常见的设计模式
对于开发人员来说,设计模式有时候就是一道坎,但是设计模式又非常有用,过了这道坎,它可以让你水平提高一个档次.而在android开发中,必要的了解一些设计模式又是非常有必要的.对于想系统的学习设计模式的 ...
- Spring源码分析 之浅谈设计模式
一直想专门写个Spring源码的博客,工作了,可以全身性的投入到互联网行业中.虽然加班很严重,但是依然很开心.趁着凌晨有时间,总结总结. 首先spring,相信大家都很熟悉了. 1.轻量级 零配置, ...
- 转 多线程 闭锁(Latch) 栅栏(CyclicBarrier)
java多线程并发系列之闭锁(Latch)和栅栏(CyclicBarrier) 标签: java并发编程 2015-05-28 16:45 2939人阅读 评论(0) 收藏 举报 本文章已收录于: . ...
- MVVM设计模式和WPF中的实现(四)事件绑定
MVVM设计模式和在WPF中的实现(四) 事件绑定 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二)数据绑定 MVVM模式解析和在WPF中 ...
- java EE设计模式简介
1.何为设计模式 设计模式提供了对常见应用设计问题的解决方案.在面向对象的编程中,设计模式通常在解决与对象创建和交互相关的问题,而非整体软件架构所面对的大规模问题,它们以样板代码的形式提供了通用的解决 ...
- 计算机程序的思维逻辑 (54) - 剖析Collections - 设计模式
上节我们提到,类Collections中大概有两类功能,第一类是对容器接口对象进行操作,第二类是返回一个容器接口对象,上节我们介绍了第一类,本节我们介绍第二类. 第二类方法大概可以分为两组: 接受其他 ...
- 《JavaScript设计模式 张》整理
最近在研读另外一本关于设计模式的书<JavaScript设计模式>,这本书中描述了更多的设计模式. 一.创建型设计模式 包括简单工厂.工厂方法.抽象工厂.建造者.原型和单例模式. 1)简单 ...
- 《JavaScript设计模式与开发实践》整理
最近在研读一本书<JavaScript设计模式与开发实践>,进阶用的. 一.高阶函数 高阶函数是指至少满足下列条件之一的函数. 1. 函数可以作为参数被传递. 2. 函数可以作为返回值输出 ...
- 设计模式之行为类模式大PK
行为类模式大PK 行为类模式包括责任链模式.命令模式.解释器模式.迭代器模式.中介者模式.备忘录模式.观察者模式.状态模式.策略 ...
随机推荐
- 数据可视化图表ECharts
介绍: ECharts是一个基于ZRender(轻量级Canvas类库)的纯javascript图表库,提供可交互.个性化的数据可视化图表. ECharts提供了折线图.柱状图.散点图.饼图.K线图, ...
- C#实现判断图形文件格式的方法
1. 通过文件的扩展名来判断.这种方法比较简单,但若是有人故意改下文件扩展名,这种方法就不起作用了. 2.通过C#自身提供的方法来进行判断(判断某种确定的图片类型). 示例如下: bool isJPG ...
- WPF Aero Glass Window
原文:WPF Aero Glass Window 用法 Win7 DwmSetWindowAttribute function Win10 SetWindowCompositionAttribute ...
- file.delete()与file.deleteOnExit(); 的区别
file.delete() //删除文件,删除的是创建File对象时指定与之关联创建的那个文件.这是一个立刻执行的操作 file.deleteOnExit(); //在JVM进程退出的时候删除 ...
- VS2008下QT整合OGRE
环境配置如下:VS2008 QT版本:4.8.1 OGRE版本: 1.7.4 请先配置好QT for vs2008 : 下载QT VS2008的包,然后下个QT VS的插件 版本必须是VS2008 ...
- LLVM和GCC的区别(LLVM提供了模块化的编译模块,非常有利于重用,以前的编译器都没有做到这一点)
最近在Mac OS X Mountain Lion下用Xcode进行开发,发现在编译选项里有如下所示的这两种编译器:一个是Apple LLVM compiler 4.2,另外一个是LLVM GCC 4 ...
- Qt官方开发环境生成的exe发布方式--使用windeployqt
Qt 官方开发环境使用的动态链接库方式,在发布生成的exe程序时,需要复制一大堆 dll,如果自己去复制dll,很可能丢三落四,导致exe在别的电脑里无法正常运行.因此 Qt 官方开发环境里自带了一个 ...
- 学习Java,值得你留意的问题(1)更名为《学习Java,容易被你忽略的小细节(1)》
记得大二快要结束的时候,有个女孩子突然问我“你会Java吗,帮我做大作业好吗?” 实话说,那个女孩真的很漂亮,我当时也非常想帮她.但是我从来没有接触过Java,让我在短短的几天内完成Java程序设计课 ...
- Cloudera Impala需求
Cloudera Impala需求 为了达到预期的效果,Impala依赖于软件.硬件的可用性,以及下面章节描述的配置. 继续阅读: 支持的操作系统 支持的Hadoop发布 Hive Metastore ...
- 这里有123个黑客必备的Python工具!
123个Python渗透测试工具,当然不仅于渗透~ 如果你想参与漏洞研究.逆向工程和渗透,我建议你时候用Python语言.Python已经有很多完善可用的库,我将在这里把他们列出来. 这个清单里的工具 ...