arm-linux

http://armboard.taobao.com/

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
 
Thread.stop, Thread.suspend, Thread.resumeRuntime.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,跳出死循环,或者是抛出异常,跳出死循环,结束线程。
 
3,捕获InterruptedException 运行时异常,中断当前线程。
有些执行伺服任务的线程,在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跳出死循环,结束这个线程。
 
 
 
posted on 2007-12-18 20:35  arm-linux  阅读(803)  评论(0编辑  收藏  举报