现在有t1,t2,t3三个线程,实现t1,t2线程同步执行,然后再执行t3线程,使用Java实现该程序

news/2024/11/26 5:26:30/

目录

1、利用CountDownLatch

2、利用Future


最近在面试的时候,经常遇到这个题目,首先从题目上看,就知道考察的是多线程方面知识,我第一次看到这个题目的时候,就想到了使用CountDownLatch这个计数器来实现,因为它的原理就是让一个线程或多个线程去等待另外线程执行完毕后再执行的,本篇文章,我打算用两种方式去实现这个题目,分别是使用CountDownLatch和Future来实现。

1、利用CountDownLatch

如果第一次听说CountDownLatch的话,也没用关系,我会用最通俗易懂的话去介绍。

CountDownLatch其实就是一个计数器,在new这个对象的时候,需要在CountDownLatch的参数中传递一个int类型的数字,并且这个int类型必须大于等于0。

而这个count值传递给Sync后,就会调用一个setState方法,这是AQS里面的内容,过多的我就不去讲述,如果有兴趣的话可以去网上搜一下AQS了解一下。这个state有三种,分别是0、1、大于1,首先0就代表着目前还没有线程去占用这个资源,可以抢占,1代表着目前已经有一个线程抢占着这个资源了,不允许其他线程再进来了,这时其他线程就会被放入到一个双向链表队列进行阻塞等待(可以去了解一下AQS的阻塞队列),大于1呢就是说这个资源被重入的次数。所以,利用该状态码值就可以实现阻塞线程。

接着介绍一下CountDownLatch的常用方法

方法名解释
await()让线程去阻塞等待
countDown()使计数器的值-1,直到减为0后,代表所有线程执行完毕
getCount()获取当前计数器值
boolean await(long timeout, TimeUnit unit)

此方法至多会等待指定的时间,超时后会自动唤醒,若 timeout 小于等于零,则不会等待。

若计数器变为零了,则返回 true;若指定的等待时间过去了,则返回 false

CountDownLatch(int count)count为计数器的初始值

示例代码

public class CountDownLatchTest {public static void main(String[] args) throws InterruptedException {CountDownLatch c = new CountDownLatch(2);//初始化一个对象,把计数器定为2new Thread(() -> {System.out.println("我是线程1");c.countDown();//计数器减一}, "t1").start();new Thread(() -> {System.out.println("我是线程2");c.countDown();//计数器减一}, "t2").start();c.await();//调用await方法,让线程3等待前两个线程执行完毕new Thread(() -> {System.out.println("我是线程3");}, "t3").start();}
}

2、利用Future

Future其实就是一个异步任务监视器,可以监视任务的执行,也可以取消任务的执行,同时也可以通过get()方法获取执行后的返回结果。

为了方便演示效果,我使用了有返回结果的Callable来实现。

Future的常用方法

方法解释
get()此方法就是获取线程池提交任务返回的结果,这个方法会一直阻塞其他线程,任务执行完毕后才会获取值。也可以传递超时时间,如果任务超过的超时时间,就会报错。
boolean isDone()判断任务是否运行完毕,如果运行完毕就返回true,否则返回false

boolean isCancelled()

判断任务是否已被取消,如果是返回true,否则false

boolean cancel(boolean mayInterruptIfRunning)

试图取消任务的执行。如果传入的参数是 true,执行任务的线程就会收到一个中断的信号,正在执行的任务可能会有一些处理中断的逻辑,进而停止。

如果传入的是 false 则就代表不中断正在运行的任务,也就是说,本次 cancel 不会有任何效果,同时 cancel 方法会返回 false。

public class FutureTest {public static void main(String[] args) throws ExecutionException, InterruptedException {//首先创建一个线程池ExecutorService executorService = Executors.newCachedThreadPool();//线程池的submit返回值类型就是FutureFuture<String> s1 = executorService.submit(new Callable<String>() {@Overridepublic String call() throws Exception {Thread.sleep(200);//模拟程序运行时间return "我是线程1";}});Future<String> s2 = executorService.submit(new Callable<String>() {@Overridepublic String call() throws Exception {Thread.sleep(200);//模拟程序运行时间return "我是线程2";}});try {System.out.println(s1.get(1000, TimeUnit.MILLISECONDS));} catch (TimeoutException e) {e.printStackTrace();}try {System.out.println(s2.get(1000, TimeUnit.MILLISECONDS));} catch (TimeoutException e) {e.printStackTrace();}if (s1.isDone() && s2.isDone()) {Thread.sleep(300);//模拟程序运行时间System.out.println("我是线程3");}executorService.shutdown();}
}


http://www.ppmy.cn/news/49761.html

相关文章

vue-qrcode生成二维码

1、安装 npm install --save qrcodejs2 2、代码 import QRCode from qrcodejs2 <div class"qrcode" ref"qrCodeUrl"></div> <script> import QRCode from qrcodejs2 export default { data() { return { }, methods: { …

设计模式:UML中的类图(6种关系)

一.UML图介绍 统一建模语言是用来设计软件的可视化建模语言。它的特点是简单、统一、图形化、能表达软件设计中的动态与静态信息。 UML 从目标系统的不同角度出发&#xff0c;定义了用例图、类图、对象图、状态图、活动图、时序图、协作图、构件图、部署图等 9 种图。 二.类图…

前端实现单元测试(代码版)

Jest使用 下载 npm install --save-dev jest ts-jest ts-node jest/globals types/jest 在nodejs中支持ts ts执行报错 npx ts-jest config:init jest 会自动运行 sum.test.js 文件&#xff0c;其默认匹配规则 匹配 test 文件夹下的 .js 文件&#xff08;.jsx .ts .tsx 也可以…

拉格朗日粒子扩散模式FLEXPART

为了高效、精准地治理区域大气污染&#xff0c;需要弄清污染物的来源。拉格朗日粒子扩散模式FLEXPART通过计算点、线、面或体积源释放的大量粒子的轨迹&#xff0c;来描述示踪物在大气中长距离、中尺度的传输、扩散、干湿沉降和辐射衰减等过程。该模式既可以通过时间的前向运算…

https相关的C API

OpenSSL是一个流行的开源加密库&#xff0c;提供了一套C API来支持HTTPS协议的实现。以下是一些常用的OpenSSL C API&#xff1a; SSL_CTX_new&#xff1a;创建SSL上下文对象SSL_new&#xff1a;创建SSL对象SSL_set_fd&#xff1a;将SSL对象与文件描述符关联SSL_connect&#…

扫描电镜学习手册

SEM测试&#xff0c;在通俗意义上来讲&#xff0c;可以看成是一个放大倍数超级大的“放大镜”。 作为当今十分有用的科学研究仪器&#xff0c;扫描电子显微镜是介于透射电镜和光学显微镜之间的一种微观性貌观察手段&#xff0c;可直接利用样品表面材料的物质性能进行微观成像。…

基于java文件压缩与解压缩实践

文件压缩与解压缩实践 摘 要 随着人们对数据的大量需求以及计算机使用时间的增加,计算机磁盘上的文件越来越大,越来越多。如何让有限的磁盘空间容纳更多的数据成为需要解决的问题。一方面,高速发展的存储技术以提高磁盘容量来解决这样的需求,但随着网络环境下数据传递…

(4.14-4.20)【大数据新闻速递】中国移动发布《数联网白皮书》;华为提出“4化”转型;国家发改委构建数据要素体系

01【“数联网”来了&#xff0c;中国移动发布《数联网&#xff08;DSSN&#xff09;白皮书》】 日前&#xff0c;中国移动正式发布数联网&#xff08;DSSN&#xff09;&#xff0c;受到业界广泛关注。这是国家宣布组建数据局以来&#xff0c;基础运营商发布的面向数据要素服务…