JUC并发编程-中断机制

2024-08-23 09:04
文章标签 并发 编程 中断 机制 juc

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

1.中断协商机制

线程不应该由其他线程来强制中断或暂停,应该由线程自己自行停止。这意味着Thead.stop,Thead.suspend,Thead.resume都已经被废弃。

在Java中没有办法立即停止一条线程,然而停止线程尤为重要,例如取消一个耗时的操作。

因此,Java提供一种用于停止线程的协商机制(中断),中断标识协商机制。

中断是一种协商机制,Java没有给中断添加任何语法,中断的过程完全由程序员自己实现。

如果想中断一个线程,可以手动调用interrupt方法,该方法也仅仅将线程对象的中断标识设置为true,接着你需要写代码不断检查当前线程的标识位,如果为true,则表示别的线程请求该线程中断。

每个线程对象都有一个中断标识位,用于表示线程是否被中断,该标识位为true表示中断,标识位为false表示未中断;通过调用线程对象的interrupt方法将线程标识位设置为true。既可以在别的线程中调用,也可以在自己的线程中调用。

2. 中断3大方法

  • interrupt():当调用某个线程的 interrupt() 方法时,该线程的中断状态将被设置为 true。如果该线程当前被 Object.wait()Thread.join() 或 Thread.sleep() 方法阻塞,那么线程的中断状态将被清除,并且线程将接收到一个 InterruptedException。如果该线程在运行中且没有阻塞在这些方法上,那么中断状态将被设置,但线程将继续运行,除非它定期检查中断状态。
  • interrupted()用于检查当前线程是否已被中断,并清除当前线程的中断状态。如果当前线程的中断状态被设置,则返回 true,并且在返回前清除中断状态。
  • isInterrupted():它用于检查调用此方法的线程是否已被中断。如果线程的中断状态被设置,则返回 true,否则返回 false。此方法不会清除线程的中断状态。

3. 通过volatile实现线程中断停止

public class VolatileInterruptExample {// 使用volatile关键字确保可见性private static volatile boolean running = true;public static void main(String[] args) throws InterruptedException {Thread workerThread = new Thread(() -> {while (running) {// 执行任务...System.out.println("线程正在运行...");// 为了演示,我们在这里加入一个简单的延时try {Thread.sleep(1000);} catch (InterruptedException e) {// 当线程被中断时,通常会抛出InterruptedException// 在这里我们可以选择退出循环,也可以选择其他逻辑System.out.println("线程被中断,退出循环");break;}}System.out.println("线程已停止");});// 启动线程workerThread.start();// 主线程暂停一段时间,然后设置running为false来停止工作线程Thread.sleep(3500);running = false;// 等待工作线程结束workerThread.join();System.out.println("主线程结束");}
}
  • 我们定义了一个volatile布尔变量running,它用来控制工作线程的执行。
  • 工作线程在它的run方法中运行一个循环,循环的条件是runningtrue
  • 在主线程中,我们让工作线程运行一段时间后,通过将running设置为false来停止工作线程。
  • 工作线程在检测到running变为false后,会退出循环并结束运行。

volatile关键字确保了running变量的改变对所有线程立即可见,这是实现线程安全的一个重要特性。当主线程修改running的值时,工作线程能够立即看到这个变化,从而正确地响应停止信号。

4. 通过AutomicBoolean实现线程中断停止

AtomicBoolean 提供了原子操作布尔值的方法。使用 AtomicBoolean 可以安全地在多个线程之间共享一个布尔值

import java.util.concurrent.atomic.AtomicBoolean;public class AtomicBooleanInterruptExample {// 使用AtomicBoolean来确保线程安全private static AtomicBoolean running = new AtomicBoolean(true);public static void main(String[] args) throws InterruptedException {Thread workerThread = new Thread(() -> {while (running.get()) {// 执行任务...System.out.println("线程正在运行...");// 为了演示,我们在这里加入一个简单的延时try {Thread.sleep(1000);} catch (InterruptedException e) {// 当线程被中断时,通常会抛出InterruptedExceptionSystem.out.println("线程被中断,退出循环");break;}}System.out.println("线程已停止");});// 启动线程workerThread.start();// 主线程暂停一段时间,然后设置running为false来停止工作线程Thread.sleep(3500);running.set(false);// 等待工作线程结束workerThread.join();System.out.println("主线程结束");}
}

  • 我们创建了一个 AtomicBoolean 类型的 running 变量,并初始化为 true
  • 工作线程在它的 run 方法中运行一个循环,循环的条件是 running.get() 返回 true
  • 在主线程中,我们让工作线程运行一段时间后,通过调用 running.set(false) 来停止工作线程。
  • 工作线程在检测到 running 变为 false 后,会退出循环并结束运行。

AtomicBoolean 的 get 和 set 方法保证了操作的原子性,这意味着在多线程环境中,这些操作不会被其他线程中断,从而保证了线程安全。这是 AtomicBoolean 优于普通布尔变量的一个重要方面。使用 AtomicBoolean,我们不需要担心可见性和原子性问题,因为它内部已经处理了这些问题。

5. 通过interrupt实现线程中断

在需要中断单点线程中不断监听中断状态,一旦发生中断,就执行相应中断处理业务逻辑停止线程。

public class InterruptExample {public static void main(String[] args) throws InterruptedException {// 创建一个线程Thread workerThread = new Thread(() -> {while (!Thread.currentThread().isInterrupted()) {// 执行任务...System.out.println("线程正在运行...");// 模拟耗时操作try {Thread.sleep(1000);} catch (InterruptedException e) {// 在这里捕获InterruptedException异常// 这通常是我们想要中断线程的地方System.out.println("线程在sleep期间被中断");// 由于中断状态被清除,我们需要重新设置中断状态Thread.currentThread().interrupt();// 选择退出循环或者进行其他清理工作break;}}System.out.println("线程已停止");});// 启动线程workerThread.start();// 主线程暂停一段时间,然后中断工作线程Thread.sleep(3500);workerThread.interrupt();// 等待工作线程结束workerThread.join();System.out.println("主线程结束");}
}
  • 我们创建了一个工作线程,它在一个循环中执行任务,并在每次迭代后调用Thread.sleep(1000)来模拟耗时操作。
  • 循环的条件是!Thread.currentThread().isInterrupted(),这意味着如果线程的中断状态被设置,循环将终止。
  • 当工作线程在sleep期间被中断时,会抛出InterruptedException。在catch块中,我们捕获了这个异常。
  • 在捕获InterruptedException后,我们通过调用Thread.currentThread().interrupt()重新设置了线程的中断状态,因为在抛出InterruptedException后,中断状态会被清除。
  • 我们选择退出循环,这样线程就可以执行任何必要的清理操作,然后退出。

6. 中断协商深度解析

(1)调用 interrupt() 时,如果线程处于正常活动状态,会将线程的中断标识设置为true,被设置中断标识的线程将继续正常运行,不受影响。

(2)中断不活动的线程不会产生任何影响,使用interrupt后,isInterrupted的结果为false

(3)线程处于阻塞状态,在别的线程中调用当前线程的interrupt方法,那么线程将立即退出被阻塞的状态,并抛出一个InterruptedException异常。

这篇关于JUC并发编程-中断机制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

go动态限制并发数量的实现示例

《go动态限制并发数量的实现示例》本文主要介绍了Go并发控制方法,通过带缓冲通道和第三方库实现并发数量限制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录带有缓冲大小的通道使用第三方库其他控制并发的方法因为go从语言层面支持并发,所以面试百分百会问到

Go语言并发之通知退出机制的实现

《Go语言并发之通知退出机制的实现》本文主要介绍了Go语言并发之通知退出机制的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、通知退出机制1.1 进程/main函数退出1.2 通过channel退出1.3 通过cont

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

Java中的xxl-job调度器线程池工作机制

《Java中的xxl-job调度器线程池工作机制》xxl-job通过快慢线程池分离短时与长时任务,动态降级超时任务至慢池,结合异步触发和资源隔离机制,提升高频调度的性能与稳定性,支撑高并发场景下的可靠... 目录⚙️ 一、调度器线程池的核心设计 二、线程池的工作流程 三、线程池配置参数与优化 四、总结:线程

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

MySQL中的锁机制详解之全局锁,表级锁,行级锁

《MySQL中的锁机制详解之全局锁,表级锁,行级锁》MySQL锁机制通过全局、表级、行级锁控制并发,保障数据一致性与隔离性,全局锁适用于全库备份,表级锁适合读多写少场景,行级锁(InnoDB)实现高并... 目录一、锁机制基础:从并发问题到锁分类1.1 并发访问的三大问题1.2 锁的核心作用1.3 锁粒度分