java線程池[轉]

來源:互聯網
上載者:User

標籤:

Executor是一個頂層介面,在它裡面只聲明了一個方法execute(Runnable),傳回值為void,參數為Runnable類型,

從字面意思可以理解,就是用來執行傳進去的任務的;

然後ExecutorService介面繼承了Executor介面,並聲明了一些方法:submit、invokeAll、invokeAny以及shutDown等;

抽象類別AbstractExecutorService實現了ExecutorService介面,基本實現了ExecutorService中聲明的所有方法;

然後ThreadPoolExecutor繼承了類AbstractExecutorService。

 

 

Executors這個工具類中提供了如下靜態方法:

  • Executors.newCachedThreadPool() 無限大小的線程池,線程會自動重用
  • Executors.newFixedThreadPool(int) 固定線程數的線程池
  • Executors.newSingleThreadExecutor() 單線程執行器

 

 

按照Executors類中的幾個Factory 方法,分別使用的是:

  • LinkedBlockingQueue。FixedThreadPool和SingleThreadExecutor使用的是這個BlockingQueue,隊列長度是無界的,適合用於提交任務相互獨立無依賴的情境。
  • SynchronousQueue。  CachedThreadPool使用的是這個BlockingQueue,通常要求線程池不設定最大的線程數,以保證提交的任務有機會執行而不被丟掉。通常這個適合任務間有依賴的情境。

當然,開發人員也可以定製ThreadPoolExecutor時使用ArrayBlockingQueue有界隊列

 

java線程池[轉]

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.