JUC并发包下的工具类

2024-01-23 18:58
文章标签 工具 juc 发包

本文主要是介绍JUC并发包下的工具类,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、闭锁CountDownLatch

作用:让当前线程等到一组事件发生后再继续执行

举例:比如,运动员和裁判员,裁判员线程需要等到所有的运动员线程到达之后才可以宣布比赛结束

闭锁中几个重要的方法

         (1)构造方法:public CountDownLatch(int count):count【需要等待的线程数】

         (2)public void countDown():线程每调用一次,等待线程的计数器-1(也就是说运动员线程每执行一次,裁判线程计数器-1)

        (3)public void await()throws InterruptedException():调用这个方法的线程会阻塞直到计数器减为0

代码如下:


import java.util.concurrent.CountDownLatch;public class TestCountDownLatch {public static void main(String[] args) {CountDownLatch latch=new CountDownLatch(3);Runnable runnable=new Sport(latch);Thread threadA=new Thread(runnable,"运动员A");Thread threadB=new Thread(runnable,"运动员B");Thread threadC=new Thread(runnable,"运动员C");System.out.println("比赛开始");threadA.start();threadB.start();threadC.start();try {latch.await();} catch (InterruptedException e) {e.printStackTrace();}System.out.println("比赛结束");}static class Sport implements Runnable{CountDownLatch latch;public Sport(CountDownLatch latch){this.latch=latch;}@Overridepublic void run() {try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName()+"到达");latch.countDown();}}
}

执行结果:

注意:CountDownLatch的对象,当计数器减为0时,不可恢复,也就是不能再用了

二、循环栅栏CyclicBarrier

作用:若干个线程等待所有的线程都到达同一个状态之后,再恢复执行

举例:比如,开会,已知有5个人参加会议,那么到达的每一个人都需要等待5个人全部都到了这一状态才可以开始开会

几个重要的方法:
         (1)public  CyclicBarrier(int parties)

         (2)public CyclicBarrier(int parties,Runnable barrrierAction)

                    parties:同时等待的线程个数            barrrierAction:恢复执行之前,随机挑选一个线程执行该任务

代码如下:


import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;public class TestCyclicBarrier {public static void main(String[] args) {System.out.println("等待开会");//当所有线程到达barrier状态后,会从所有线程中随机选择一个来执行RunnableCyclicBarrier barrier=new CyclicBarrier(3, new Runnable() {@Overridepublic void run() {System.out.println(Thread.currentThread().getName());}});Runnable task=new Participant(barrier);new Thread(task,"员工A").start();new Thread(task,"员工B").start();new Thread(task,"员工C").start();}
}
class Participant implements Runnable{CyclicBarrier barrier;public Participant(CyclicBarrier barrier){this.barrier=barrier;}@Overridepublic void run() {try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName()+"到达");try {barrier.await();} catch (InterruptedException e) {e.printStackTrace();} catch (BrokenBarrierException e) {e.printStackTrace();}System.out.println("开始开会");}
}

运行结果如下:可以看到barrrierAction是在恢复执行之前,随机挑选一个线程执行这个任务

注意:CyclicBarrier的对象的值可以恢复,reset()方法,可以重复使用

 

****闭锁和循环栅栏看起来很类似

                都是阻塞等待其他线程,但是侧重点不同:

                闭锁是只某个线程去等待一组线程结束之后再恢复执行;而循环栅栏是指一组线程都要等到该组线程执行到某个状态之后,再恢复执行

 

三、Exchanger--线程交换器

作用:两两线程配对后交换数据再同时恢复执行,若线程调用Exchanger.exchange(),缓冲区只有一个线程,

则当前线程阻塞,直到有另一个线程调用Exchanger.exchange(),两线程交换数据

举例:密码的验证,信息的交换,都需要进行数据的交换,就以两个人说话为例

代码如下:

import java.util.concurrent.Exchanger;/*** 用于线程间协作的工具类,它提供一个同步点,在这个同步点,两个线程可以交货彼此的数据* 通过exchange交换数据,如果第一个线程先执行了exchange()方法,它会已知等待第二个线程也执行exchange()方法* 当两个线程都到达同步点时,这两个线程就可以交换数据了,将本线程生产出来的数据传递给对方*/
public class TestExchanger {public static void main(String[] args) {Exchanger<String> exchanger=new Exchanger<>();Runnable boy=new boy(exchanger);Runnable girl=new girl(exchanger);new Thread(boy,"Thread-boy").start();new Thread(girl,"Thread-girl").start();}
}
class boy implements Runnable {Exchanger<String> exchanger;public boy(Exchanger exchanger){this.exchanger=exchanger;}@Overridepublic void run() {System.out.println("我是男方");try {String result=exchanger.exchange("男方说的话");System.out.println(Thread.currentThread().getName()+":"+result);} catch (InterruptedException e) {e.printStackTrace();}}
}
class girl implements Runnable{Exchanger<String> exchanger;public girl(Exchanger exchanger){this.exchanger=exchanger;}@Overridepublic void run() {System.out.println("我是女方");try {String result=exchanger.exchange("女方说的话");System.out.println(Thread.currentThread().getName()+":"+result);} catch (InterruptedException e) {e.printStackTrace();}}
}

执行结果如下:可以看到数据进行了交换,双方都接收到了对方的信息数据

这篇关于JUC并发包下的工具类的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/637221

相关文章

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

基于C#实现PDF文件合并工具

《基于C#实现PDF文件合并工具》这篇文章主要为大家详细介绍了如何基于C#实现一个简单的PDF文件合并工具,文中的示例代码简洁易懂,有需要的小伙伴可以跟随小编一起学习一下... 界面主要用于发票PDF文件的合并。经常出差要报销的很有用。代码using System;using System.Col

redis-cli命令行工具的使用小结

《redis-cli命令行工具的使用小结》redis-cli是Redis的命令行客户端,支持多种参数用于连接、操作和管理Redis数据库,本文给大家介绍redis-cli命令行工具的使用小结,感兴趣的... 目录基本连接参数基本连接方式连接远程服务器带密码连接操作与格式参数-r参数重复执行命令-i参数指定命

Python pyinstaller实现图形化打包工具

《Pythonpyinstaller实现图形化打包工具》:本文主要介绍一个使用PythonPYQT5制作的关于pyinstaller打包工具,代替传统的cmd黑窗口模式打包页面,实现更快捷方便的... 目录1.简介2.运行效果3.相关源码1.简介一个使用python PYQT5制作的关于pyinstall

使用Python制作一个PDF批量加密工具

《使用Python制作一个PDF批量加密工具》PDF批量加密‌是一种保护PDF文件安全性的方法,通过为多个PDF文件设置相同的密码,防止未经授权的用户访问这些文件,下面我们来看看如何使用Python制... 目录1.简介2.运行效果3.相关源码1.简介一个python写的PDF批量加密工具。PDF批量加密

使用Java编写一个文件批量重命名工具

《使用Java编写一个文件批量重命名工具》这篇文章主要为大家详细介绍了如何使用Java编写一个文件批量重命名工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录背景处理1. 文件夹检查与遍历2. 批量重命名3. 输出配置代码片段完整代码背景在开发移动应用时,UI设计通常会提供不

Python按条件批量删除TXT文件行工具

《Python按条件批量删除TXT文件行工具》这篇文章主要为大家详细介绍了Python如何实现按条件批量删除TXT文件中行的工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.简介2.运行效果3.相关源码1.简介一个由python编写android的可根据TXT文件按条件批

详解Python中通用工具类与异常处理

《详解Python中通用工具类与异常处理》在Python开发中,编写可重用的工具类和通用的异常处理机制是提高代码质量和开发效率的关键,本文将介绍如何将特定的异常类改写为更通用的ValidationEx... 目录1. 通用异常类:ValidationException2. 通用工具类:Utils3. 示例文

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只