結論基本和linux c 的相同java
package com.test.api;linux
import java.util.concurrent.ArrayBlockingQueue;api
import java.util.concurrent.ExecutorService;ide
import java.util.concurrent.Executors;源碼分析
import java.util.concurrent.ThreadPoolExecutor;spa
import java.util.concurrent.TimeUnit;線程
class Th implements Runnable{隊列
@Override文檔
public void run() {源碼
while(true){
System.out.println("------------");
Thread.yield();
/*try {
Thread.sleep(1000*5);//ok
} catch (InterruptedException e) {
System.out.println("exception ");
// TODO Auto-generated catch block
e.printStackTrace();
}*/
}
}
}
public class Cache {
private static ExecutorService threadPool = Executors.newFixedThreadPool(4);
public static void main(String[] args) {
Th t = new Th();
/*Thread h = new Thread(t);
h.start();
h.interrupt();*/
threadPool.execute(t);
threadPool.shutdownNow();
while(true){}
}
}
shutDown()
當線程池調用該方法時,線程池的狀態則馬上變成SHUTDOWN狀態。此時,則不能再往線程池中添加任何任務,不然將會拋出RejectedExecutionException異常。可是,此時線程池不會馬上退出,直到添加到線程池中的任務都已經處理完成,纔會退出。
shutdownNow()
根據JDK文檔描述,大體意思是:執行該方法,線程池的狀態馬上變成STOP狀態,並試圖中止全部正在執行的線程,再也不處理還在池隊列中等待的任務,固然,它會返回那些未執行的任務。
它試圖終止線程的方法是經過調用Thread.interrupt()方法來實現的,可是你們知道,這種方法的做用有限,若是線程中沒有sleep 、wait、Condition、定時鎖等應用, interrupt()方法是沒法中斷當前的線程的。因此,ShutdownNow()並不表明線程池就必定當即就能退出,它可能必需要等待全部正在執行的任務都執行完成了才能退出。
上面對shutDown()以及shutDownNow()做了一個簡單的、理論上的分析。若是想知道why,則須要親自打開JDK源碼,分析分析。
想要分析shutDown()以及shutDownNow()源碼,我建議首先要對ThreadPoolExecutor有個大概瞭解。由於關閉線程池的全部方法邏輯都在ThreadPoolExecutor中處理的。
若是你真的想知道爲何,建議看一下我之前寫的一篇對ThreadPoolExecutor源碼分析的博文,我想這對你比較透徹的瞭解shutDown()和shutDownNow()的區別以及java 線程池原理有很大的幫助。