常見線程池
1、newSingleThreadExecutor
創建一個單線程化的線程池,它只會用唯一的工作線程來執行任務,保證所有任務按照指定順序(FIFO, LIFO, 優先級)執行。
從構造方法來看,它可以單獨執行,也可以與周期線程池結合用。其任務隊列是LinkedBlockingQueue,這是個無界的阻塞隊列,因為線程池里只有一個線程,就確保所有的任務都在同一個線程中順序執行,這樣就不需要處理線程同步的問題。這類線程池適用于多個任務順序執行的場景。
2、newFixedThreadPool
創建一個定長線程池,可控制線程最大并發數,超出的線程會在隊列中等待。
一個固定大小的線程池,可以用于已知并發壓力的情況下,對線程數做限制。
這類線程池的特點就是里面全是核心線程,沒有非核心線程,也沒有超時機制,任務大小也是沒有限制的,數量固定,即使是空閑狀態,線程不會被回收,除非線程池被關閉,從構造方法也可以看出來,只有兩個參數,一個是指定的核心線程數,一個是線程工廠,keepAliveTime無效。任務隊列采用了無界的阻塞隊列LinkedBlockingQueue,執行execute方法的時候,運行的線程沒有達到corePoolSize就創建核心線程執行任務,否則就阻塞在任務隊列中,有空閑線程的時候去取任務執行。由于該線程池線程數固定,且不被回收,線程與線程池的生命周期同步,所以適用于任務量比較固定但耗時長的任務。
3、newCache