终止stop(已经过时),这是一种恶意中断,导致线程逻辑不完整比如下列代码中“休眠被终止”代表的逻辑区域,如果使用stop,线程A将被彻底清除栈信息,sleep中的逻辑将无法完整就被处理掉,而如果使用了interrupt()及时中断了A,逻辑区代码也会执行。最后才消灭A
Interrupt()本身不是中断线程的方法,仅仅是改变了中断标志,一个程序里面不书写sleep的无限运行run方法线程,使用interrupt不会终止,此时需要进行判断在run()中写while(!isInterrupted()){
……
}
使用interrupt,sleep会抛出异常,以此来return结束线程:
public class MyThread implements Runnable{
@Override
public void run() {
// TODO Auto-generated method stub
System.out .println("进入run方法");
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
//e.printStackTrace();
System.out .println("休眠被终止");
return;//返回被调用出
}
System.out.println("run正常结束");
}
}
public class InterruptDemo {
public static void main(String[] args) {
// TODO Auto-generated method stub
MyThread t = new MyThread();
Thread T = new Thread(t,"线程A");
T.start();//休眠10s
try {
Thread.sleep(2000);//main线程等两秒再实施对A的中断
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("中断前A的状态是"+T.getState()+"存活?"+T.isAlive());
T.interrupt();
System.out.println("中断后A的状态是"+T.getState()+"存活?"+T.isAlive());
}
}
使用stop方法代替interrupt:
public class InterruptDemo {
public static void main(String[] args) {
// TODO Auto-generated method stub
MyThread t = new MyThread();
Thread T = new Thread(t,"线程A");
T.start();//休眠10s
try {
Thread.sleep(2000);//main线程等两秒再实施对A的中断
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("stop前A的状态是"+T.getState()+"存活?"+T.isAlive());
T.stop();
System.out.println("stop后A的状态是"+T.getState()+"存活?"+T.isAlive());
}
stop导致catch没有以及sleep后面方法未进行。
在下面可以看出去掉return(上面未去掉时,回到run()调用处,及相当于run执行完,进入死亡态);虽然因为interrupt使得休眠10s后会出现catch的代码块,但是run方法休眠之后还会继续运行,故A的状态在休眠结束前和中断后是存活的。如此侧面证明,interrupt本身不能终止线程而是作为一种判断标准。