多线程—interrupt()⽅法
1、⾸先⼤家应该知道sleep()、wait()、join()调⽤者三个⽅法可以使得线程阻塞,线程阻塞之后,cpu是不会分配时间⽚的。
2、interrupt()⽅法:
san francisco作⽤:打断线程。
1、打断处于阻塞状态的线程。
2、打断正在运⾏的线程。
注意:
1、当使⽤interrupt()⽅法去打断处于阻塞状态的线程时,会以异常的⽅式打印,⽽不会更新打断标记,因此,虽然被打断,但是打断标记依然为fal。
2、当使⽤interrupt()⽅法去打断正在运⾏线程时,被打断的线程会继续运⾏,但是该线程的打断标记会更新,更新为true,因此可以根据打断标记来作为判断条件使得线程停⽌。
jason bateman
这⾥不得不说的多线程的⼀个设计模式——两阶段终⽌模式
/**
qualitycontrol
* 两阶段终⽌模式
* @author
* @since 2021/9/28
**/
cable modem
@Slf4j
public class TestMain {
public static void main(String[] args) throws InterruptedException {
ThreadTest threadTest = new ThreadTest();
threadTest.start();
creative designThread.sleep(3000);
threadTest.stop();
}
}
@Slf4jbifer
class ThreadTest{
private Thread thread;
/**
* 监控线程启动
*/
public void start(){
thread= new Thread(()-> {
while(true){
//获取当前线程
Thread current = Thread.currentThread();
//判断监控线程是否被打断
if (current.isInterrupted()){ //isInterrupted判断完后不会清除打断标记,但是interrupted⽅法判断完后会清除 log.debug("处理善后");
break;
}
try {
Thread.sleep(1000); //打断情况1:会进⼊异常
log.debug("监控继续执⾏");//打断情况2:不会进⼊异常
} catch (InterruptedException e) {贝勒医学院
e.printStackTrace();
//如果是在睡眠的时候被打断,那么会进⼊catch,⽽且打断状态不会更新,所以才重新设置打断标记
current.interrupt();
}
}
});
thread.start();
}
/**
* 停⽌监控线程
*/
public void stop(){
thread.interrupt();
}
}
部分注释使⽤了⾏尾注释,为了⼤家⽅便理解,真正开发中使⽤⾏尾注释是不规范的。blocking
xinkai>okinawa