Java并发编程之闭锁与栅栏的实现

 更新时间:2020年04月30日 10:03:24   转载 作者:与李  
这篇文章主要介绍了Java并发编程之闭锁与栅栏的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、前言

闭锁与栅栏是在多线程编程中的概念,因为在多线程中,我们不能控制线程的执行状态,所以给线程加锁,让其按照我们的想法有秩序的执行。

闭锁

CountDownLatch,实例化时需要传入一个int类型的数字(count),意为等待count个线程完成之后才能执行下一步动作。

如今天要做的事情是吃晚饭,再去散步。假设11个人相约晚饭后一起去散步,我们得等11个人全都吃完晚饭了才能出发去散步。简而言之就是做了才到达某一种状态。

栅栏

CyclicBarrier,实例化时需要传入一个int类型的数字(parties),意为等待parties个线程都准备就绪后才能执行自己的任务。

如今天要做的事情是吃晚饭,8个人约好一起去某餐厅吃饭,得等到人齐了才能去吃饭。简而言之就是到达某种状态后一起做。

二、实例

闭锁 CountDownLatch

package com.test;
 
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CountDownLatch;
 
public class Test {
 public static void main(String[] args) {
 CountDownLatch latch = new CountDownLatch(3);
 
        // 模拟三个任务
 List<String> jobs = new ArrayList<String>();
 jobs.add("first");
 jobs.add("second");
 jobs.add("third");
    
        // 循环执行任务
 for (String job : jobs) {
  new Thread(new Runnable() {
 
  @Override
  public void run() {
   System.out.println(Thread.currentThread().getName() + " : 进入run方法");
   latch.countDown();
   System.out.println(Thread.currentThread().getName() + " : 执行" + job);
  }
  }).start();
 }
 
 try {
  latch.await();
 } catch (InterruptedException e) {
  e.printStackTrace();
 }
 // 任务都执行完后才执行
 System.out.println("回到main线程");
 }
 
}

执行结果:

Thread-1 : 进入run方法

Thread-2 : 进入run方法

Thread-2 : 执行third

Thread-0 : 进入run方法

Thread-1 : 执行second

Thread-0 : 执行first

回到main线程

通过执行结果可看出,当所有线程都执行完后才能回到主线程继续执行后面的输出。

栅栏 CyclicBarrier

package com.test;
 
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
 
public class Test {
 public static void main(String[] args) {
 CyclicBarrier barrier = new CyclicBarrier(3);
 // 模拟创建三个任务
 List<String> jobs = new ArrayList<String>();
 jobs.add("first");
 jobs.add("second");
 jobs.add("third");
 //循环执行任务
 for (String job : jobs) {
  new Thread(new Runnable() {
 
  @Override
  public void run() {
   System.out.println(Thread.currentThread().getName() + " : 进入run方法");
   try {
   // 等待
   barrier.await();
   } catch (InterruptedException | BrokenBarrierException e) {
   e.printStackTrace();
   }
   System.out.println(Thread.currentThread().getName() + " : 执行" + job);
  }
  }).start();
 }
 } 
}

执行结果:

Thread-1 : 进入run方法

Thread-2 : 进入run方法

Thread-0 : 进入run方法

Thread-0 : 执行first

Thread-1 : 执行second

Thread-2 : 执行third

通过执行结果可看出,当所有线程都执行都进入到run方法后,才能继续执行自己内部的方法。

到此这篇关于Java并发编程之闭锁与栅栏的实现的文章就介绍到这了,更多相关Java 闭锁与栅栏内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 使用java执行定时任务示例

    使用java执行定时任务示例

    这篇文章主要介绍了使用java执行定时任务示例,需要的朋友可以参考下
    2014-04-04
  • java实现两个文件的拼接

    java实现两个文件的拼接

    这篇文章主要为大家详细介绍了java实现两个文件的拼接,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-07-07
  • Java 的双重分发与 Visitor 模式实例详解

    Java 的双重分发与 Visitor 模式实例详解

    这篇文章主要介绍了Java 的双重分发与 Visitor 模式实例详解,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-07-07
  • Tomcat 服务器 在45秒内未启动成功的解决方法

    Tomcat 服务器 在45秒内未启动成功的解决方法

    下面小编就为大家带来一篇Tomcat 服务器 在45秒内未启动成功的解决方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11
  • 详解java并发编程(2) --Synchronized与Volatile区别

    详解java并发编程(2) --Synchronized与Volatile区别

    这篇文章主要介绍了Synchronized与Volatile区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • java实现短信通信的完整教程

    java实现短信通信的完整教程

    这篇文章主要为大家详细介绍了java实现短信通信的完整教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • Java多线程Runable售票系统实现过程解析

    Java多线程Runable售票系统实现过程解析

    这篇文章主要介绍了Java多线程Runable售票系统实现过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-06-06
  • Java中枚举的使用详解

    Java中枚举的使用详解

    这篇文章主要介绍了Java中枚举的使用详解的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-07-07
  • Java基于TCP方式的二进制文件传输

    Java基于TCP方式的二进制文件传输

    这篇文章主要为大家介绍了Java基于TCP方式的二进制文件传输,一个基于Java Socket协议之上文件传输的完整示例,基于TCP通信完成,感兴趣的小伙伴们可以参考一下
    2016-01-01
  • 理解java多线程中ExecutorService使用

    理解java多线程中ExecutorService使用

    这篇文章主要帮助大家理解java多线程中ExcetorServiced的使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12

最新评论