首页 > 编程语言 >Java线程 interrupt 方法使用异常

Java线程 interrupt 方法使用异常

时间:2024-12-20 13:52:53浏览次数:3  
标签:10 12 Java 中断 2024 线程 信号 interrupt 20

背景

需要在异步任务中中断任务的执行,故选择通过调用 interrupt 方法对线程设置中断信号。
在比较耗时的业务代码增加判断 Thread.currentThread().isInterrupted() 抛出异常停止任务执行,并回退任务。

问题

中断信号发出后,任务线程一直未检测到中断信号状态。
以下为测试结论。

第一次测试

无任何其他操作,只在各个阶段打印日志时间和线程中断状态。
观察信号中断时间和报表内日志的打印时间,判断报表程序中在哪个节点获取到的中断信号。

日志示例

中断信号发起时间

2024-12-20 09:52:23:011 erp-gl [XNIO-1 task-1] INFO c.u.c.c.c.ErpGlobalController[71] TxId=6664fc8e-0596-4012-8d23-ebd40de9977f SpanId= GLOBAL-终止线程=[ERP-REQ-10342620]

任务内各阶段中断信号校验时间

2024-12-20 09:52:17:253 erp-gl [ERP-REQ-10342620] INFO c.u.gl.program.GlReportTotalTypeAc[104] TxId= SpanId= 中断信号01 2024-12-20 09:52:17,false

2024-12-20 09:52:17:539 erp-gl [ERP-REQ-10342620] INFO c.u.gl.program.GlReportTotalTypeAc[138] TxId= SpanId= 中断信号02 2024-12-20 09:52:17,false

中断信号03 2024-12-20 09:52:41,false

中断信号04 2024-12-20 09:52:55,false

中断信号05 2024-12-20 09:53:12,false

中断信号06 2024-12-20 09:53:13,false

中断信号07 2024-12-20 09:53:14,false

结论:一直到程序执行完并未获取到中断信号,或者中断信号被某段代码重置。

第二次测试

在第一次测试的基础上,添加while代码
观察在未执行业务代码之前是否能获取到中断信号

中断信号发起时间

2024-12-20 10:08:34:978 erp-gl [XNIO-1 task-1] INFO c.u.c.c.c.ErpGlobalController[71] TxId=666a7b26-7f52-4ac4-b45a-c7c0e04ec75e SpanId= GLOBAL-终止线程=[ERP-REQ-10342620]

任务内各阶段中断信号校验时间

中断信号01 2024-12-20 10:08:31,false

2024-12-20 10:08:34:978 erp-gl [ERP-REQ-10342620] INFO c.u.gl.program.GlReportTotalTypeAc[163] TxId= SpanId= 捕获到中断信号时间: 2024-12-20 10:08:34

中断信号02 2024-12-20 10:08:34,true

中间有数据批量插入操作,中断信号被重置

中断信号03 2024-12-20 10:08:57,false

以下各阶段均为 false

结论:数据库插入操作将中断信号重置

第三次测试

调整while 位置,观察是否是因为数据库插入操作将中断信号重置

中断信号发起时间

2024-12-20 10:17:10:759 erp-gl [XNIO-1 task-1] INFO c.u.c.c.c.ErpGlobalController[71] TxId=66632106-d9f7-4210-afe3-95794f2ff6bc SpanId= GLOBAL-终止线程=[ERP-REQ-10342620]

任务内各阶段中断信号校验时间

中断信号01 2024-12-20 10:17:06,false

中断信号02 2024-12-20 10:17:06,false

while 循环操作,未获取到中断信号日志

中断信号03 2024-12-20 10:28:19,false

以下各阶段均为 false

结论:数据库插入操作导致中断信号被重置。

第四次测试

在第三次测试的基础上,注释 所有数据库插入操作,观察中断信号是否被重置

中断信号发起时间

2024-12-20 10:39:16:373 erp-gl [XNIO-1 task-1] INFO c.u.c.c.c.ErpGlobalController[71] TxId=6663bc98-bd9d-499e-aee4-28932e4c468f SpanId= GLOBAL-终止线程=[ERP-REQ-10342620]

任务内各阶段中断信号校验时间

中断信号01 2024-12-20 10:39:12,false

中断信号02 2024-12-20 10:39:12,false

捕获到中断信号时间: 2024-12-20 10:39:16

中断信号03 2024-12-20 10:39:16,true

中断信号04 2024-12-20 10:39:16,true

中间为双重for循环数据处理,没有任何数据插入操作,中断信号被重置

中断信号05 2024-12-20 10:39:32,false

结论:未确定哪行代码将中断信号重置。

标签:10,12,Java,中断,2024,线程,信号,interrupt,20
From: https://www.cnblogs.com/good--luck/p/18619124

相关文章

  • Java 项目愚蠢的分层及解决方案
    《整洁架构之道》的最后一章《细节决定成败》又在讨论Javaer永恒的问题:分层后DAOServiceController应该按功能分包还是按层分包。按功能分包的人认为这些文件在业务上是一起的,应该放在同一个包。按层分包的人认为每个层代表了不同的技术,应该按层分包。可以想象,按层分包的......
  • 排查Java进程占用CPU高的原因
    背景一般java程序占用cpu内存都不会太高,出现占用高的情况,第一反应就是,进程在某个地方死循环了。排查top-Hp15057查看下进程中的线程资源占用情况由上图可见,CPU时间片主要是被15393这个线程给吃掉了,所以目标锁定在15393。执行printf"%x\n"15393,计算出线程ID......
  • javaweb地方农产品特产展销系统
    目录项目介绍具体实现截图开发核心技术:写作提纲开发过程思路核心代码部分展示实验方案:详细视频演示源码获取方式项目介绍选题则旨在通过标签分类管理等方式,实现管理员;个人中心、用户管理、特产商品管理、商品类型管理、我的收藏管理、系统管理、订单管理,用户;个人中......
  • 师生交流系统|Java|SSM|JSP|
                   【技术栈】1⃣️:架构:B/S、MVC2⃣️:系统环境:Windowsh/Mac3⃣️:开发环境:IDEA、JDK1.8、Maven、Mysql5.7+4⃣️:技术栈:Java、Mysql、SSM、Mybatis-Plus、JSP、jquery,html5⃣️数据库可视化工具:navicat6⃣️服务器:SpringBoot自带apache......
  • 少儿编程教育系统|Java|SSM|JSP| 
                            【技术栈】1⃣️:架构:B/S、MVC2⃣️:系统环境:Windowsh/Mac3⃣️:开发环境:IDEA、JDK1.8、Maven、Mysql5.7+4⃣️:技术栈:Java、Mysql、SSM、Mybatis-Plus、JSP、jquery,html5⃣️数据库可视化工具:navicat6⃣️服......
  • 新闻发布系统|Java|SSM|JSP| 
                 【技术栈】1⃣️:架构:B/S、MVC2⃣️:系统环境:Windowsh/Mac3⃣️:开发环境:IDEA、JDK1.8、Maven、Mysql5.7+4⃣️:技术栈:Java、Mysql、SSM、Mybatis-Plus、JSP、jquery,html5⃣️数据库可视化工具:navicat6⃣️服务器:SpringBoot自带apachetomcat......
  • 师生交流系统|Java|SSM|JSP| 
                            【技术栈】1⃣️:架构:B/S、MVC2⃣️:系统环境:Windowsh/Mac3⃣️:开发环境:IDEA、JDK1.8、Maven、Mysql5.7+4⃣️:技术栈:Java、Mysql、SSM、Mybatis-Plus、JSP、jquery,html5⃣️数据库可视化工具:navicat6⃣️服......
  • 少儿编程教育系统|Java|SSM|JSP| 
                            【技术栈】1⃣️:架构:B/S、MVC2⃣️:系统环境:Windowsh/Mac3⃣️:开发环境:IDEA、JDK1.8、Maven、Mysql5.7+4⃣️:技术栈:Java、Mysql、SSM、Mybatis-Plus、JSP、jquery,html5⃣️数据库可视化工具:navicat6⃣️服......
  • 网络直播带货查询系统:SSM 框架的 JAVA 设计与 JSP 开发实现
    第三章系统分析3.1系统设计目标网络直播带货网站主要是为了用户方便对商品信息的了解以及查看商品分类和查看订单信息,也是为了更好的让管理员进行更好存储所有数据信息及快速方便的检索功能,对系统的各个模块是通过许多今天的发达系统做出合理的分析来确定考虑用户的可操......
  • 《刚刚问世》系列初窥篇-Java+Playwright自动化测试-8- 元素高级定位技巧(详细教程)
    1.简介随着网页的复杂性和动态性的增加,自动化测试变得越来越重要。Playwright作为一款强大的无头浏览器测试库,提供了多种元素定位方式,使得我们能够轻松地对网页进行自动化操作。在基础的定位方式如通过id、classname和tagname等之外,Playwright还提供了更高级的定位技巧,如nth()......