-
方法、捕获InterruptedException 运行时异常,中断当前线程。 有些执行伺服任务的线程,在while(true)这样的死循环内部,是一个阻塞中的方法。此时,就不能采用第二种方法了。因为,当该方法没有返回时,该线程会一直处于阻塞当中,根本无法执行其他语句。这时候就需要调用该线程的interrupt方法,产生一个InterruptedException运行时异常,是阻塞中的那个方法抛出这个异常,从而让我们有机会结束这个线程的执行。 如: @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跳出死循环,结束这个线程。 以上所介绍的便是Java中断线程的基本方法,也从安全角度出发所提倡的三种中断线程的方法,希望予以正确引用
public class ThreadDemo extends Thread{
public static void main(String[] args) throws InterruptedException {Thread thread = new ThreadDemo();
thread.start();
thread.sleep(100);
thread.interrupt(); //中断线程
}
@Override
public void run() {
while (!Thread.currentThread().isInterrupted()) {
System.out.println( "thread running" );
try {
Thread.sleep(100);
} catch (InterruptedException e)
{
System.out.println( "InterruptedException" );
Thread.currentThread().interrupt(); //再次中断线程
//break;
}
}
System.out.println( "thread interrupted" );
}
}
简单总结:
1. 线程start()后马上调用interrupt(),在进入run()时中断标志已经被set on;
2. 在处理sleep()可能抛出的InterruptedException时,再次中断线程即可成功中断;
3. 注意interrupt()方法是set on 中断标志的,interrupted()方法是判断后并清除中断标志的。