同步工具类-闭锁CountDownLatch
来源:互联网 发布:网络恐怖主义案例 编辑:程序博客网 时间:2024/05/20 13:10
闭锁
延迟线程的进度直到到达终止状态。相当于一扇门,在闭锁到达结束状态之前,这扇门一直是关闭着的。并没有任何线程能够通过。当到达结束状态时,这扇门会打开允许所有的线程通过。闭锁可以用来确保某些活动直到其他活动都完成后才继续执行。闭锁只可以使用一次。
1. 确保某个操作在其所需要的所有资源都被初始化后才能继续执行,二元闭锁可以用来表示”资源R已经被初始化”。
2. 确保某个服务在其所依赖的其他服务都已经启动之后才启动,每个服务都有一个相关的二元闭锁。启动服务S时,S在依赖的所有其他服务的闭锁上等待。
3. 等待直到某个操作的所有参与者都就绪再继续执行。这种情况中,闭锁将达到结束状态。
CountDownLatch是一种灵活的闭锁实现,可以用于上述的各种情况中,可以使一个或多个线程等待一组事件发生。
countDown方法递减计数器,await方法等待计数器达到零,或者等待中的线程中断,或者超时。
案例:如果我们需要在所有线程创建完毕后才开始线程的运行,可以在主线程中设置一个为二元闭锁,线程创建后,在这个闭锁等待,等待所有创建完成后,进行一个countdown,所以所有创建好的线程可以在这时开始运行。
import java.util.concurrent.CountDownLatch;public class ColletcionsPackageTest { public long timeTasks(int nThreads, final Runnable task) throws InterruptedException { final CountDownLatch startGate = new CountDownLatch(1); final CountDownLatch endGate = new CountDownLatch(nThreads); for (int i = 0; i < nThreads; i++) { Thread thread = new Thread(new Runnable() { @Override public void run() { // TODO Auto-generated method stub try { startGate.await(); try { task.run(); } finally{ // TODO: handle exception endGate.countDown(); } } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }); } long start=System.currentTimeMillis(); startGate.countDown(); endGate.await(); long end=System.currentTimeMillis(); return end-start; }}
0 0
- 同步工具类-闭锁CountDownLatch
- 同步工具类一:闭锁(java.util.concurrent.CountDownLatch)
- 同步工具类一:闭锁(java.util.concurrent.CountDownLatch)
- 同步工具类--闭锁
- 同步工具类-闭锁
- CountDownLatch同步工具类
- CountDownLatch同步工具类
- 同步工具类闭锁,栅栏,信号量
- Java同步工具类——闭锁
- 同步工具类之 CountDownLatch
- 闭锁CountDownLatch
- CountDownLatch 闭锁
- 闭锁 CountDownLatch
- 闭锁 CountDownLatch
- CountDownLatch闭锁
- 同步容器类和工具类4——闭锁
- 同步工具类--闭锁、信号量、栅栏的总结
- 同步工具类(闭锁,信号量,栅栏,FutureTask)
- JAVA1
- mysq中的子查询
- 面试题7:用两个栈实现队列
- UITableView的简单实用
- CentOS 6.5 与 win7 双系统时间同步问题
- 同步工具类-闭锁CountDownLatch
- 简述Java内存泄露
- SCP 从服务器上传下载文件
- swift plist文件
- android的adb命令以及测试
- Linux环境免重启安装中文字体
- 报表XML导出rtf格式,结果在浏览器中打开XML文件。下载rtf文件打开后出现Authentication failed 问题
- OC语言基本语法
- 电商系统中的商品模型的分析与设计—续