http://www.educity.cn 作者:佚名 来源:希赛教育
 Thread.stop,Thread.suspend,Thread.resume和Runtime.runFinalizersOnExit这些终止线程运行的方法已经被废弃,使用它们是极端不安全的!

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

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

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

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

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

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

    如:

    publicvoid run() {
    while(true){
    someWork();
    if(finished){
    break;
    }
    try {
    Thread.sleep(10000);
    } catch (InterruptedException e) {
    /* TODO自动生成 catch 块
    *
    */
    e.printStackTrace();
    }
    }
    }

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

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

    此时,就需要调用该线程的interrupt方法,产生一个InterruptedException运行时异常,是阻塞中的那个方法抛出这个异常,从而让我们有机会结束这个线程的执行。

    如:

    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跳出死循环,结束这个线程。