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文章来源地址https://www.toymoban.com/news/detail-524692.html
文章来源:https://www.toymoban.com/news/detail-524692.html
到了这里,关于java.lang.InterruptedException: sleep interrupted的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!