当前位置:   article > 正文

java线程暂停_Java之线程停止

try { thread.sleep(10000); } catch (interruptedexception e) { exc

public void run() {

while(true){

someWork();

if(finished){

break;

}

try {

Thread.sleep(10000);

} catch (InterruptedException e) {

e.printStackTrace();

}

}

}

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

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

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

这里说一种特殊情况,有些情况可能你需要一下子停止整个系统的所有线程,这样子上面的方法就不是那么高效,思路也差不多。例如下面的Thread1、Thread2。

public class Thread1 extends Thread {

@Override

public void run() {

while(true) {

try {

doSomeWork();

if (finished) {

break;

}

//wait for some resource

} catch (InterruptedException e) {

// ...

break;

}

}

}

}

public class Thread2 extends Thread {

@Override

public void run() {

while(true) {

try {

doSomeWork();

if (finished) {

break;

}

//wait for some resource

} catch (InterruptedException e) {

// ...

break;

}

}

}

}

显然,通过上面那两种方法不能一下子停止这些线程,因为我们不能做到这些线程能同时满足条件,此外这些线程也不可能一块堵塞。这里我们通过改变whlie条件来解决这个问题,在我们的Thread1、Thread2上面增加一个父类AbstractThread,例:

public abstract class AbstractThread extends Thread {

protected AtomicBoolean isRunning = new AtomicBoolean(true);

public void stopRunning() {

isRunning.set(false);

}

}

然后使Thread1、Thread2继承AbstractThread,然后修改while循环为如下:

while(isRunning) {

...

}

在停止线程时,调用每个线程的stopRunning方法,如果存在堵塞的情况,在辅助调用该线程的interrupt方法。

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2009-08-16 22:54

浏览 15495

评论

4 楼

Nabulio

2016-08-16

50880c61e3199786f144db0328de5b6f.gif 

ccf5e5c2a4777a14201b1dce9adb5168.gif

3 楼

像胡杨树一样活着

2013-05-03

貌似我的水平很低,

0956f0a970daab536ce4be0ee96b00ac.gif 没懂。

2 楼

gauzeehom

2010-08-11

看过了

2fd2d9c1d175d11752585fa9b76aba29.gif

1 楼

zouxiyao

2010-07-08

很有用的东西

本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号