Java闭锁_CountDownLatch

闭锁是一种同步工具类,可以延迟线程的进度直到其到达终止状态。闭锁的作用相当于一扇门:在闭锁到达结束状态之前,这扇门一直是关闭的,并且没有任何线程能通过,当到达结束状态时,这扇门会打开并允许所有的线程通过。当闭锁到达结束状态后,将不会在改变状态,因此这扇门将永远保持打开状态。闭锁可以用来确定某些活动直到其他活动都完成后才继续执行,例如:

确保某个计算在其需要的所有资源都被初始化之后才继续执行。二元闭锁(包括两个状态)可以用来表示“资源R已经被初始化”,而所有需要R的操作都必须在这个闭锁上等待

确保某个服务在其依赖的所有其他服务都已经启动之后才启动。每个服务都有一个相关的二元闭锁。当启动服务S时,将首先在S 依赖的其他服务的闭锁上 等待,在所有依赖的服务都启动后会释放闭锁S,这样其他依赖S 的服务才能继续执行。

等待直到某个操作的所有参与者都就绪再继续执行。在这种情况下,当所有玩家都准备就绪时,闭锁将到达结束状态。

CountDownLatch是一种灵活的闭锁实现,可以在上述情况中使用,他可以使一个或多个线程等待一组时间发生。闭锁状态包括一个计数器,该计数器初始化为一个正数,表示需要等待的事件数量。countDown方法递减计数器,表示有一个事件发生了,而await方法等待计数器达到零,这表示所有需要等待的事件都已经发生。如果计数器的值非零,那么await会一直阻塞直到计数器为零,或者等待中的线程中断,或者等待超时。

await()方法

Causes the current thread to wait until the latch has counted down to zero

/**

* Causes the current thread to wait until the latch has counted down to

* zero, unless the thread is {@linkplain Thread#interrupt interrupted}.

*/

public void await() throws InterruptedException {

sync.acquireSharedInterruptibly(1);

}

countDown()方法

Decrements the count of the latch, releasing all waiting threads if the count reaches zero

/**

* Decrements the count of the latch, releasing all waiting threads if

* the count reaches zero.

*/

public void countDown() {

sync.releaseShared(1);

}

CountDownLatch示例

在下面这个示例中,它使用两个闭锁,分别表示起始门,和结束门。

起始门计数器的初始值为 1,而结束门计数器的初始值为工作线程的数量。每个工作线程首先要做的就是在启动门上等待,从而确保所有的线程都就绪后才开始执行。而每个线程要做的最后一件事就是将调用结束门的countDown 方法减一,这能使主线程高效的等待直到所有的工作线程都执行完成,因此可以统计所消耗的时间:

package com.lyx;

import java.util.concurrent.CountDownLatch;

public class TestHarness {

public static void main(String[] args) throws InterruptedException {

// TODO Auto-generated method stub

Runnable task = new Runnable() {

public void run() {

System.out.println("hello latch............");

}

};

System.out.println(timeTashs(100, task));

}

public static long timeTashs(int nThreads, final Runnable task)

throws InterruptedException {

final CountDownLatch startGate = new CountDownLatch(1);

final CountDownLatch endGate = new CountDownLatch(nThreads);

for (int i = 0; i

Thread t = new Thread() {

@Override

public void run() {

try {

startGate.await();//startGate 计数器为 1,等待直到计数器为零

try {

task.run();

} finally {

endGate.countDown(); //结束门计数器递减 1

}

} catch (InterruptedException e) {

// TODO: handle exception

}

}

};

t.start();

}

long start = System.nanoTime();

startGate.countDown(); //计数器减一,所有的工作线程同一时间开始工作。

endGate.await(); //主线程结束工作-If the current count is zero then this method returns immediately.

long end = System.nanoTime();

return end - start;

}

}

public long runSample(int n, final Runnable runSport) throws InterruptedException {

final CountDownLatch gun = new CountDownLatch(1);

final CountDownLatch end = new CountDownLatch(n);

for (int i = 0; i

Thread t = new Thread() {

public void run(){

try{

gun.await();//等待开枪

try{

runSport.run();

}finally{

end.countDown();

}

}catch( InterruptedException e){

Thread.currentThread().interrupt();

}

}

};

t.start();

}

long startTime = System.nanoTime();

gun.countDown();//开枪

end.await();

long endTime = System.nanoTime();

return endTime - startTime;

}

============END============

java闭锁_Java闭锁_CountDownLatch相关推荐

  1. java闭锁_Java闭锁—CountDownLatch

    CountDownLatch,它可以阻塞一个或多个线程,以等待另一组事件的发生后,继续执行被阻塞的一个或多个线程.CountDownLatch的两个核心方法:调用await方法阻塞一个或多个线程:调用 ...

  2. java火箭应用_从火箭发场景来学习Java多线程并发闭锁对象

    原标题:从火箭发场景来学习Java多线程并发闭锁对象 从火箭发场景来学习Java多线程并发闭锁对象 倒计时器场景 在我们开发过程中,有时候会使用到倒计时计数器.最简单的是:int size = 5; ...

  3. java 闭锁_从火箭发场景来学习Java多线程并发闭锁对象

    从火箭发场景来学习Java多线程并发闭锁对象 倒计时器场景 在我们开发过程中,有时候会使用到倒计时计数器.最简单的是:int size = 5; 执行后,size-这种方式来实现.但是在多线程并发的情 ...

  4. java 计时器_Java多线程并发容器之并发倒计时器

    从火箭发场景来学习Java多线程并发闭锁对象 倒计时器场景 在我们开发过程中,有时候会使用到倒计时计数器.最简单的是:int size = 5; 执行后,size-这种方式来实现.但是在多线程并发的情 ...

  5. 【源码+教程】Java课设项目_12款最热最新Java游戏项目_Java游戏开发_Java小游戏_飞翔的小鸟_王者荣耀_超级玛丽_推箱子_黄金矿工_贪吃蛇

    马上就要期末了,同学们课设做的如何了呢?本篇为大家带来了12款热门Java小游戏项目的源码和教程,助力大家顺利迎接暑假![源码+教程]Java课设项目_12款最热最新Java游戏项目_Java游戏开发 ...

  6. 黑马程序员全套Java教程_Java基础教程_异常(含扩展)(二十三)

    黑马程序员全套Java教程_Java基础教程_异常(含扩展)(二十三) 1.1 异常概述与异常体系结构 1.2 JVM遇到异常时的默认处理方案 1.3 异常处理 1.4 异常处理之try--catch ...

  7. java闭锁_Java并发工具类(闭锁CountDownLatch)

    闭锁是一种同步工具类,可以延迟线程的进度直到其到达终止状态. CountDownLatch是一种灵活的闭锁实现,它可以使一个或者多个线程等待一组事件的发生. 闭锁状态包含一个计数器,该计数器被初始化为 ...

  8. java 信号量 闭锁_Java并发包之闭锁/栅栏/信号量

    二.同步工具类详解 1.Semaphore信号量:跟锁机制存在一定的相似性,semaphore也是一种锁机制,所不同的是,reentrantLock是只允许一个线程获得锁,而信号量持有多个许可(per ...

  9. 同步机制之--java之CountDownLatch闭锁

    CountDownLatch闭锁 1.类介绍 一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待.用给定的计数初始化 CountDownLatch.CountDown ...

最新文章

  1. ActiveMQ消息的延时和定时投递
  2. 金陵科技学院c语言测试,金陵科技学院C语言实验册.doc
  3. 使用Docker实现丝般顺滑的持续集成
  4. 一般处理程序使用Session报错(未将对象引用设置到对象实例)
  5. Basic INFO - InstallScript脚本编程的限制
  6. ProgressDialog 一个使用类,多多提建议
  7. Silverlight开发历程—模糊特效与投影特效
  8. 慕课网_《Java实现对称加密》学习总结
  9. [jQuery] 通过ajax保存到服务器,成功显示信息.
  10. Streaming HTTP responses【翻译】
  11. 如何关闭OSX 10.11 SIP (System Integrity Protection)
  12. 应用随机过程_《常见随机过程》(目录)
  13. wsimport命令生成webService java客户端代码
  14. 哪一类功率放大电路效率最高_高频放大电路原理详解及应用电路汇总
  15. Android渐变背景色
  16. 问卷星问卷数据怎么快速导入SPSSAU?
  17. build vue 指定版本_vue buid及部署踩坑记录
  18. signalr php,继SignalR 持久链接 Web客户端
  19. 使用一组坐标信息拟合圆(matlab)
  20. 微小宝公众号排行榜_公众号榜单 | 2020·5月公众号地区排行榜重磅发布

热门文章

  1. FreeCAD 官方文档 —— 一、 概述
  2. Firefox 禁止中国用户!!
  3. C语言结构体变量 指针以及对结构体成员的访问
  4. Feign客户端异常IOException: Incomplete output stream解决方案
  5. 五款堪称神器的网页翻译插件,不知道就亏大了!
  6. LORA1276/1278 CAD检测功能测试
  7. Android手机不同频率的听力测试功能实现
  8. 网页验证码显示在输入框input上的方法
  9. org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.cy.pj.goods.dao
  10. 全量备份/增量备份/差异备份说明