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

作者:与李 时间:2022-01-09 15:00:12 

一、前言

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

闭锁

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方法后,才能继续执行自己内部的方法。

来源:https://blog.csdn.net/qq_37171817/article/details/105789565

标签:Java,闭锁,栅栏
0
投稿

猜你喜欢

  • 心动吗?正大光明的免费使用IntelliJ IDEA商业版

    2023-11-25 04:29:48
  • JAVA各种OOM代码示例与解决方法

    2023-01-23 04:28:00
  • Java结构型设计模式之享元模式示例详解

    2022-05-16 21:41:10
  • Mybatis初始化知识小结

    2023-11-01 13:59:27
  • SpringBoot使用protobuf格式的接口方式

    2022-02-14 14:20:17
  • 浅谈SpringBoot中的@Conditional注解的使用

    2021-12-07 16:47:04
  • C#利用com操作excel释放进程的解决方法

    2022-08-02 07:01:28
  • java实现五子棋程序

    2022-01-29 10:40:38
  • Java日期与时间类原理解析

    2021-07-20 14:00:36
  • java 如何判断是否是26个英文字母

    2023-11-29 15:51:59
  • Java 把json对象转成map键值对的方法

    2023-08-25 01:58:14
  • 详解Java实现LRU缓存

    2023-06-05 19:24:08
  • Java servlet、filter、listener、interceptor之间的区别和联系

    2023-11-02 15:32:17
  • 使用ehcache三步搞定springboot缓存的方法示例

    2021-06-25 04:44:12
  • Java实现提取QSV文件视频内容

    2023-08-24 13:33:45
  • Spring的@Validation和javax包下的@Valid区别以及自定义校验注解

    2021-06-20 04:06:35
  • 深入理解Java虚拟机体系结构

    2021-09-15 19:46:53
  • SpringMVC实现多文件上传

    2023-10-12 16:49:15
  • 详解Java泛型及其应用

    2023-09-21 22:38:32
  • java 如何实现正确的删除集合中的元素

    2022-08-03 17:44:31
  • asp之家 软件编程 m.aspxhome.com