java.lang.InterruptedException: sleep interrupted

java.lang.InterruptedException: sleep interrupted
	at java.lang.Thread.sleep(Native Method)
	at com.test.thread.CallableTest.call(CallableTest.java:34)
	at com.test.thread.CallableTest.call(CallableTest.java:6)
	at java.util.concurrent.FutureTask.run(FutureTask.java:266)
	at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
	at java.util.concurrent.FutureTask.run(FutureTask.java:266)
	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
	at java.lang.Thread.run(Thread.java:748)
Picked up JAVA_TOOL_OPTIONS:  -Dfile.encoding=UTF-8

线程的暂停有两个方法 shutdown 与shutdownNow 两个方法的调用都会阻止新任务的提交,区别是关于已经提交未完成任务的处理以及线程终端的处理,shutdown会继续执行并且完成所有未执行的任务,shutdownNow 会清除所有未执行的任务并且在运行线程上调用interrupt() 。
我的理解:该异常产生的原因是有任务还没有执行完成,就调用shutdownNow方法。
​ 调用shutdownnow()方法退出线程池时,线程池会向正在运行的任务发送Interrupt,任务中的阻塞操作会响应这个中断并抛出InterruptedException,但同时会清除线程的Interrupted 状态标识,导致后续流程感知不到线程的中断了。要想立即停止线程池中任务最好的方式就是直接向任务传递退出信号。
参考:
https://blog.csdn.net/liulipuo/article/details/39004279
https://blog.csdn.net/mucaoyx/article/details/109153721

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值