線程的取消
以前的什麼stop() suspend()方法都已經別取消了,那如何安全的終止線程呢?
我們在多線程編程中,總是會終止線程,那該如何操作呢?
今天看《Java併發編程藝術》這本書,在書中學到一種終止線程的方法。
通過設置標誌位,通過檢測標誌位來覺得是否要終止線程
- 標誌位用 volatile 來修飾,滿足可見性。
代碼如下:
public class Runner implements Runnable {
private long i;
private volatile boolean on =true;
@Override
public void run() {
while(on && !Thread.currentThread().isInterrupted()){
i++;
}
System.out.println("Count i:"+ i);
}
public void cancel(){
on= false;
}
}
執行類:
public class ShutDown {
public static void main(String[] args) throws InterruptedException {
Runner run = new Runner();
Thread countThread = new Thread(run,"CountThread");
countThread.start();
TimeUnit.SECONDS.sleep(1);
countThread.interrupt();
Runner runner01= new Runner();
countThread= new Thread(runner01,"CountThead");
countThread.start();
TimeUnit.SECONDS.sleep(1);
runner01.cancel();
}
}
- 通過cancle()方法來終止線程,然而cancle()方法只是將標誌位設置爲falese。
關於線程終止,喚醒理解
不管是要終止的線程還是喚醒的線程,都要先獲得該對象的鎖。
每個對象都有自己的鎖,線程要對對象進行操作,會通過對象的監聽器來嘗試獲取該對象鎖,如果獲取成功才能在該對象上進行相應的操作。
-
以前一直沒明白對象鎖的作用,通過上面的圖,有了大概的瞭解。
-
調用notify()/notifyAll()將線程從等待狀態編程阻塞狀態。
等待/通知機制
流程如下:
- 加鎖
- 條件循環
- 處理邏輯
1、 等待方遵守的條件
2、通知方遵守的條件