1.三个方法:
interrupt()
表示一个运行中的线程是否被其他线程进行了中断操作
被调用中断的线程可以通过调用isInterrupted来判断是否被中断
被调用中断的线程如果一直在运行的话,那么线程会继续运行,不受影响
被调用中断的线程如果处于被阻塞状态,那么会退出并抛出异常
isinterrupted()
只会返回线程中断状态,不会修改标志位。
interrupted()
返回当前线程的中断状态,然后会将线程的中断状态清除,也就是将标志位设置为false。
2.停止线程的三种方法
https://www.cnblogs.com/lixuwu/p/10766125.html
1)标志位 + valotile
复制代码
public class ThreadSafe extends Thread {
public volatile boolean exit = false;
public void run() {
while (!exit){
//do something
}
}
}
复制代码
2)interrupt + isInterrupted
复制代码
public class TestThread extends Thread {
@Override
public void run() {
while (!isInterrupted()) {
try {
// do something
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
}
}
}
}
TestThread testThread = new TestThread();
testThread.start();
// 一段时间以后
testThread.interrupt();
复制代码
使用interrupt()方法来中断线程有两种情况:
1.线程处于阻塞状态,如使用了sleep,同步锁的wait,socket中的receiver,accept等方法时,会使线程处于阻塞状态。当调用线程的interrupt()方法时,会抛出InterruptException异常。阻塞中的那个方法抛出这个异常,通过代码捕获该异常,然后重新在catch代码块中将中断标志位置为true。通常很多人认为只要调用interrupt方法线程就会结束,实际上是错的, 一定要先捕获InterruptedException异常之后通过重新设置标志位跳出循环,才能正常结束run方法。
2.线程未处于阻塞状态,使用isInterrupted()判断线程的中断标志来退出循环。当使用interrupt()方法时,中断标志就会置true,和使用自定义的标志来控制循环是一样的道理。
为什么要区分进入阻塞状态和和非阻塞状态两种情况了,是因为当阻塞状态时,如果有interrupt()发生,系统除了会抛出InterruptedException异常外,还会调用interrupted()函数,调用时能获取到中断状态是true的状态,调用完之后会复位中断状态为false,所以异常抛出之后通过isInterrupted()是获取不到中断状态是true的状态,从而不能退出循环
3)使用stop()方法中断线程
程序中可以直接使用thread.stop()来强行终止线程,但是stop方法是很危险的,就象突然关闭计算机电源,而不是按正常程序关机一样,可能会产生不可预料的结果,不安全主要是:thread.stop()调用之后,创建子线程的线程就会抛出ThreadDeatherror的错误,并且会释放子线程所持有的所有锁。一般任何进行加锁的代码块,都是为了保护数据的一致性,如果在调用thread.stop()后导致了该线程所持有的所有锁的突然释放(不可控制),那么被保护数据就有可能呈现不一致性,其他线程在使用这些被破坏的数据时,有可能导致一些很奇怪的应用程序错误。因此,并不推荐使用stop方法来终止线程。
有相同爱好的可以进来一起讨论哦:企鹅群号:1046795523
学习视频资料:http://www.makeru.com.cn/live/1392_1164.html?s=143793