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

Logo

腾讯云面向开发者汇聚海量精品云计算使用和开发经验,营造开放的云计算技术生态圈。

更多推荐