CountDownLatch

 Java 5.0 在 java.util.concurrent 包中提供了多种并发容器类来改进同步容器的性能

CountDownLatch 一个同步辅助类,在完成一组正在其他线程中执行的操作
  之前,它允许一个或多个线程一直等待

闭锁可以延迟线程的进度直到其到达终止状态,闭锁可以用来确保某些活
  动直到其他活动都完成才继续执行:
     确保某个计算在其需要的所有资源都被初始化之后才继续执行;
     确保某个服务在其依赖的所有其他服务都已经启动之后才启动;
     等待直到某个操作所有参与者都准备就绪再继续执行

闭锁:

在完成某些运算时,只有其他所有线程的运算全部完成,当前运算才继续执行

案例:测试线程执行的时间

public class TestCountDownLatch {
public static void main(String[] args) {
final CountDownLatch latch = new CountDownLatch();
LatchDemo ld = new LatchDemo(latch); //计算执行时间
long start = System.currentTimeMillis();
for(int i=;i<;i++){
new Thread(ld).start();
} long end = System.currentTimeMillis();
System.out.println("线程执行的时间为:" + (start -end));
}
} class LatchDemo implements Runnable{ private CountDownLatch countDownLatch; public LatchDemo(CountDownLatch latch){
this.countDownLatch = latch;
} @Override
public void run() { for(int i= ;i<;i++){
if(i%==){
System.out.println(i);
}
}
}
}

此时无法得到10个子线程的执行时间

因为在子线程执行完成之前main函数的线程已经执行完毕

此时我们需要设置main函数线程在10个子线程执行完毕之后再执行

进行修改设置:

public class TestCountDownLatch {
public static void main(String[] args) {
final CountDownLatch latch = new CountDownLatch();
LatchDemo ld = new LatchDemo(latch); //计算执行时间
long start = System.currentTimeMillis();
for(int i=;i<;i++){
new Thread(ld).start();
} try {
latch.await();
} catch (InterruptedException e) {
e.printStackTrace();
}
long end = System.currentTimeMillis();
System.out.println("线程执行的时间为:" + (start -end));
} } class LatchDemo implements Runnable{ private CountDownLatch countDownLatch; public LatchDemo(CountDownLatch latch){
this.countDownLatch = latch;
} @Override
public void run() { synchronized(this){
try {
for(int i= 0;i<5000;i++){
if(i%2==0){
System.out.println(i);
}
}
} finally {
//递减1
countDownLatch.countDown();
}
}

}
}

main函数中有10个线程

所以需要设置10个闭锁

每个线程执行之后都需要将其的值进行减一

所以在线程中:

synchronized:此时可能出现同部数据的设置

使用CountDownLatch的countDown()方法将其值进行递减1

同时需要使用await()放法进行等待所有线程执行完成之后再执行之后的代码

所以会在最后进行打印10个线程消耗的时间:

4、JUC--CountDownLatch闭锁的更多相关文章

  1. juc并发工具类之CountDownLatch闭锁

    import java.util.concurrent.CountDownLatch; /** * 闭锁: 在进行某些运算时, 只有其他所有线程的运算全部完成,当前运算才继续执行(程序流中加了一道栅栏 ...

  2. CountDownLatch闭锁

    CountDownLatch是一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待. 闭锁可以延迟线程的进度直到其到达终止状态,闭锁可以用来确保某些活动直到其他活动都完 ...

  3. CopyOnWriteArrayList(写入并复制) & CountDownLatch(闭锁)

    ConcurrentHashMap: ①Java 5.0 在 java.util.concurrent 包中提供了多种并发容器类来改进同步容器 的性能.② ConcurrentHashMap 同步容器 ...

  4. 6. CountDownLatch 闭锁

    package com.gf.demo05; import java.util.concurrent.CountDownLatch; /** * CountDownLatch : 闭锁,在完成某些操作 ...

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

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

  6. 【同步工具类】CountDownLatch闭锁任务同步

    [同步工具类]CountDownLatch闭锁任务同步 转载:https://www.cnblogs.com/yangchongxing/p/9214284.html 打过dota的同学都知道,多人一 ...

  7. Java并发编程笔记之 CountDownLatch闭锁的源码分析

    JUC 中倒数计数器 CountDownLatch 的使用与原理分析,当需要等待多个线程执行完毕后在做一件事情时候 CountDownLatch 是比调用线程的 join 方法更好的选择,CountD ...

  8. CountDownLatch(闭锁)

    一.闭锁(Latch)    闭锁(Latch):一种同步方法,可以延迟线程的进度直到线程到达某个终点状态.通俗的讲就是,一个闭锁相当于一扇大门,在大门打开之前所有线程都被阻断,一旦大门打开所有线程都 ...

  9. CountDownLatch——闭锁的实现之一

    CountDownLatch实际上是一种闭锁实现.闭锁:是一种同步工具类,可以延迟线程的进度知道其到达终止状态--<Java并发编程实战>.这个怎么解释呢?简单来说,就是有1个线程需要等待 ...

  10. CountDownLatch 闭锁、FutureTask、Semaphore信号量、Barrier栅栏

    同步工具类可以是任何一个对象.阻塞队列可以作为同步工具类,其他类型的同步工具类还包括信号量(Semaphore).栅栏(Barrier).以及闭锁(Latch). 所有的同步工具类都包含一些特定的结构 ...

随机推荐

  1. [日常] Go语言圣经--示例: 并发的Echo服务

    最简单的回声服务器: package main import ( "io" "net" "log" ) func main() { list ...

  2. 安装svn过程

    1.SVN服务器端程序安装 --检测是否安装成功:svn --version2.创建版本库(仓库) 命令格式:svnadmin create 仓库的目录 3.启动服务器 <1>命令行方式 ...

  3. tomcat日志切割和定期删除(转载)

    tomcat日志切割和定期删除 在tomcat的软件环境中,如果我们任由日志文件无限增长,总有一天会将磁盘占满的(废话).特别是在日志文件增长速度很快的一些情况下,按日志切割日志文件并删除,就是一件很 ...

  4. SpringCloud高可用和高并发

    1 高可用 什么是高可用:(High Availability)在一个长时间内服务不受影响.通俗的讲就是,一个机器挂掉的时候,有其他机器可以继续提供同样的服务. 如何实现高可用:冗余+自动故障转移.冗 ...

  5. Spring、Springmvc整合web的web.xml配置

    <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http:// ...

  6. Java高级工程师需要弄明白的20个知识点

    一般的程序员或许只需知道一些JAVA的语法结构,能对数据库数据进行CRUD就可以应付了.但要成为JAVA(高级) 工程师,就要对JAVA做比较深入的研究,需要不断学习进步,以下对高级工程师需要突破的知 ...

  7. 【 js 基础 】【 源码学习 】 深浅拷贝

    underscore的源码中,有很多地方用到了 Array.prototype.slice() 方法,但是并没有传参,实际上只是为了返回数组的副本,例如 underscore 中 clone 的方法: ...

  8. CSS图标文字不对齐

    页面排版经常遇到‘图标+文字’的需求,正常样式写下来是这样 ​, 但产品要的应该是长这样 ​,怎么办呢?其实很简单,加个样式看看 vertical-align: top/middle/bottom; ...

  9. CPA理论与Base理论

    CPA理论: 由于对系统或者数据进行了拆分,我们的系统不再是单机系统,而是分布式系统,针对分布式系统的CAP原理包含如下三个元素. C:Consistency,一致性.在分布式系统中的所有数据 备份, ...

  10. hibernate动态表名映射

    引自:http://blog.csdn.net/xvshu/article/details/39187779 最近的一个项目有一个需求,有N个考核单位,要对每个考核单位生成一张考核情况表,这样做的目的 ...