[背景    中断(Interrupt)一个线程意味着在该线程完成任务之前停止其正在进行的一切,有效地中止其当前的操作。线程是死亡、还是等待新的任务或是继续运行至下一步,就取

Thread.stop, Thread.suspend, Thread.resume 和Runtime.runFinalizersOnExit 这些终止线程运行的方法已经被废弃,使用它们是极端不安全的!

现在,如果你要安全有效地终止一个线程,应该采用以下这些方法:

1,线程正常执行完毕,正常结束。

也就是让run方法执行完毕,该线程就会正常结束。

2,监视某些条件,结束线程的不间断运行。

然而,常常有些线程是伺服线程。它们需要长时间的运行,只有在外部某些条件满足的情况下,才能关闭这些线程。

通常,它们执行在一个while(true)的死循环中。

如:

@Override

publicvoid run() {

while(true){

someWork();

if(finished){

break;

}

try {

Thread.sleep(10000);

} catch (InterruptedException e) {

/* TODO自动生成 catch 块

*

*/

e.printStackTrace();

}

}

}

我们可以在while死循环内,每次循环时,察看外部条件,看看是否需要关闭当前线程。如果是,就break,跳出死循环,或者是抛出异常,跳出死循环,结束线程。

有些执行伺服任务的线程,在while(true)这样的死循环内部,是一个阻塞中的方法。此时,就不能采用第二种方法了。因为,当该方法没有返回时,该线程一直处于阻塞当中,根本无法执行其他语句。

如:

@Override

publicvoid run() {

while(true){

try {

// getSendMessages 是BlockingQueue类。它的take方法将会阻塞!

responseMessage = this.getSendMessages().take();

} catch (InterruptedException e1) {

thrownew RuntimeException();

//或者break;

}

someWork();

}

一个外部的Thread 对象 指向这个线程。 需要结束这个线程时,只需要调用thread对象的interrupt() 方法,就会在

responseMessage = this.getSendMessages().take();

这条语句中产生一个InterruptedException异常,从而结束该线程的阻塞状态,通过抛出异常,或者break跳出死循环,结束这个线程。[PART.1 无法中断的线程一个无法中断的线程的例子。public class UninterruptableThread{    @SuppressWarnings(deprecation)    public static void main(String[] args)


版权声明:本文为weixin_36139228原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/weixin_36139228/article/details/115043602