java线程的6个状态中,Terminated为终止,Thread普通方法interrupt()可以使线程标记为终止状态。
首先,我们希望线程的执行都在非终止标记下进行,因此每时每刻都应该进行如下的判断以检查线程是否为终止状态,不是的话再运行...
if (!Thread.currentThread().isInterrupted()) {...}
而实际写代码中,我们并不用写下这样的判断,而且我们也做不到随时判断,这个工作应该是底层(具体不清楚)已经帮我们做了。
然后,当线程进入阻塞状态而中断线程继续往下执行,如调用了
Thread.sleep(1000);
那么上面的isInterrupted判断无法进行 ,这时这段空档时间无法保证该线程的状态为非终止状态,
如果此时在它的父线程调用了它的interrupt(),该线程变为终止状态,而为了处理终止状态,在if判断不可以使用的情况下,引入了InterruptedException,抛出异常,这是一种检查型异常,必须对其进行捕捉处理,以此确保线程终止状态的变化是可察觉的可控的。可用如下代码观察:
public static void main(String[] args) {
Thread t = new Thread(() -> {
for (int i = 0; i < 10; i++) {
System.out.println("线程t");
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
t.start();
t.interrupt();
}
运行结果:
ps:在写这篇的时候突然想到一个问题:sleep是静态方法,我们知道对象也可以调用,那么在父线程中使用子线程t.sleep这样调用会发生什么?是子线程sleep还是父线程(主线程)sleep?我测了下是父线程sleep,静态方法就是静态方法哈
如有误解,恳请批评指正!