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 行为类模式包括责任链模式.命令模式.解释器模式.迭代器模式.中介者模式.备忘录模式.观察者模式.状态模式.策略 ...
随机推荐
- DevExpress的xtraMessageBox汉化
原文:DevExpress的xtraMessageBox汉化 项目使用的界面库是DevExpress 相当好用,不过里面弹出对话框XtraMessageBox的按钮都是英文的, 可能会对用户造成困扰, ...
- WIN10从2016.11开始就强制驱动必须要求经过WHQL认证,而2015的win10就没有问题
http://www.whqlchina.com/whql-news/whql-following/ https://www.zhihu.com/question/45586031 https://a ...
- vs编译在win xp电脑上运行的win32程序遇到的问题记录(无法定位程序输入点GetTickCount64于动态链接库KERNEL32.dll)
直接编译后运行,弹出提示框:不是有效的win32应用程序 像之前那样把msvcr110.dll复制过去依然报错: 这是因为vs2012编译的win32程序用到的系统函数在xp环境上对应不上.之前转载的 ...
- QML Settings 小的示例
QML 中使用 Settings 可以保存一些简单的信息,例如用户名,密码,窗口位置,大小等,没有Sqlite那么麻烦,简单易用哦~~~(环境:Qt5.8 for android ,Windows ...
- 青云QingCloud黄允松:最高效的研发管理就是没有管理
摘要: 对于底层技术创新而言,没有管理是最好的管理,小规模作战,快速试错,迅速转变方向,迭代周期一定要短. 钛媒体注:钛媒体.商业价值联合主办的第五届“MIIC移动互联网创新大会”如期举行.2015 ...
- Qt5---ftp上传功能(可直接克隆某个小模块,查看QT下FTP的socket原理)
http://blog.csdn.net/freeape/article/details/52802163
- c#与JAVA利用SOCKET实现异步通信的SanNiuSignal.DLL已开源
大家好,前段时间C#的SanNiuSignal.DLL已开源;因部分用户特需要JAVA版的SanNiuSignal;现在只能把半成品先拿出来暂时给他们用了,以后再慢慢改进; JAVA版目前已实现跟C# ...
- SQL基础复习1
一.概述 SQL语言组成:DDL,DCL,DML 二.数据定义 1.模式定义(Schema) Schema这个东西一直感觉不大明白,一直以为就是对表的字段定义则被称为Schema,在复习数据库理论中才 ...
- C# 中使用不安全代码(unsafe、指针)实践
命题 根据指定的字符集合(字典),按排列组合的规则(允许重复),生成指定长度的所有字符串.如下代码: class Program { static void Main(string[] args) { ...
- .NET错误:The tag 'BusyIndicator' ('CallMethodAction')does not exist in XML namespace
将一个项目由VS2010升级为VS2012后,在确保代码无误的情况下编译程序出现以下错误提示: 解决方法:将4.0.0.0的程序集Microsoft.Expression.Interactions.及 ...