[Java四種線程池的使用](http://cuisuqiang.iteye.com/blog/2019372)
Java通過Executors提供四種線程池,分別為:
newCachedThreadPool創建一個可緩存線程池,如果線程池長度超過處理需要,可靈活回收空閑線程,若無可回收,則新建線程。
newFixedThreadPool 創建一個定長線程池,可控制線程最大并發數,超出的線程會在隊列中等待。
newScheduledThreadPool 創建一個定長線程池,支持定時及周期性任務執行。
newSingleThreadExecutor 創建一個單線程化的線程池,它只會用唯一的工作線程來執行任務,保證所有任務按照指定順序(FIFO, LIFO, 優先級)執行。
**(1) newCachedThreadPool**
創建一個可緩存線程池,如果線程池長度超過處理需要,可靈活回收空閑線程,若無可回收,則新建線程。示例代碼如下:
Java代碼?
1. package?test;??
2. import?java.util.concurrent.ExecutorService;??
3. import?java.util.concurrent.Executors;??
4. public?class?ThreadPoolExecutorTest?{??
5. ?public?static?void?main(String[]?args)?{??
6. ??ExecutorService?cachedThreadPool?=?Executors.newCachedThreadPool();??
7. ??for?(int?i?=?0;?i?10;?i++)?{??
8. ???final?int?index?=?i;??
9. ???try?{??
10. ????Thread.sleep(index?*?1000);??
11. ???}?catch?(InterruptedException?e)?{??
12. ????e.printStackTrace();??
13. ???}??
14. ???cachedThreadPool.execute(new?Runnable()?{??
15. ????public?void?run()?{??
16. ?????System.out.println(index);??
17. ????}??
18. ???});??
19. ??}??
20. ?}??
21. }??
線程池為無限大,當執行第二個任務時第一個任務已經完成,會復用執行第一個任務的線程,而不用每次新建線程。
(2) newFixedThreadPool
創建一個定長線程池,可控制線程最大并發數,超出的線程會在隊列中等待。示例代碼如下:
Java代碼?
1. package?test;??
2. import?java.util.concurrent.ExecutorService;??
3. import?java.util.concurrent.Executors;??
4. public?class?ThreadPoolExecutorTest?{??
5. ?public?static?void?main(String[]?args)?{??
6. ??ExecutorService?fixedThreadPool?=?Executors.newFixedThreadPool(3);??
7. ??for?(int?i?=?0;?i?10;?i++)?{??
8. ???final?int?index?=?i;??
9. ???fixedThreadPool.execute(new?Runnable()?{??
10. ????public?void?run()?{??
11. ?????try?{??
12. ??????System.out.println(index);??
13. ??????Thread.sleep(2000);??
14. ?????}?catch?(InterruptedException?e)?{??
15. ??????e.printStackTrace();??
16. ?????}??
17. ????}??
18. ???});??
19. ??}??
20. ?}??
21. }??
因為線程池大小為3,每個任務輸出index后sleep 2秒,所以每兩秒打印3個數字。
定長線程池的大小最好根據系統資源進行設置。如Runtime.getRuntime().availableProcessors()
(3)? newScheduledThreadPool
創建一個定長線程池,支持定時及周期性任務執行。延遲執行示例代碼如下:
Java代碼??
1. package?test;??
2. import?java.util.concurrent.Executors;??
3. import?java.util.concurrent.ScheduledExecutorService;??
4. import?java.util.concurrent.TimeUnit;??
5. public?class?ThreadPoolExecutorTest?{??
6. ?public?static?void?main(String[]?args)?{??
7. ??ScheduledExecutorService?scheduledThreadPool?=?Executors.newScheduledThreadPool(5);??
8. ??scheduledThreadPool.schedule(new?Runnable()?{??
9. ???public?void?run()?{??
10. ????System.out.println("delay?3?seconds");??
11. ???}??
12. ??},?3,?TimeUnit.SECONDS);??
13. ?}??
14. }??
表示延遲3秒執行。
定期執行示例代碼如下:
Java代碼?
1. package?test;??
2. import?java.util.concurrent.Executors;??
3. import?java.util.concurrent.ScheduledExecutorService;??
4. import?java.util.concurrent.TimeUnit;??
5. public?class?ThreadPoolExecutorTest?{??
6. ?public?static?void?main(String[]?args)?{??
7. ??ScheduledExecutorService?scheduledThreadPool?=?Executors.newScheduledThreadPool(5);??
8. ??scheduledThreadPool.scheduleAtFixedRate(new?Runnable()?{??
9. ???public?void?run()?{??
10. ????System.out.println("delay?1?seconds,?and?excute?every?3?seconds");??
11. ???}??
12. ??},?1,?3,?TimeUnit.SECONDS);??
13. ?}??
14. }??
表示延遲1秒后每3秒執行一次。
(4) newSingleThreadExecutor
創建一個單線程化的線程池,它只會用唯一的工作線程來執行任務,保證所有任務按照指定順序(FIFO, LIFO, 優先級)執行。示例代碼如下:
Java代碼
1. package?test;??
2. import?java.util.concurrent.ExecutorService;??
3. import?java.util.concurrent.Executors;??
4. public?class?ThreadPoolExecutorTest?{??
5. ?public?static?void?main(String[]?args)?{??
6. ??ExecutorService?singleThreadExecutor?=?Executors.newSingleThreadExecutor();??
7. ??for?(int?i?=?0;?i?10;?i++)?{??
8. ???final?int?index?=?i;??
9. ???singleThreadExecutor.execute(new?Runnable()?{??
10. ????public?void?run()?{??
11. ?????try?{??
12. ??????System.out.println(index);??
13. ??????Thread.sleep(2000);??
14. ?????}?catch?(InterruptedException?e)?{??
15. ??????e.printStackTrace();??
16. ?????}??
17. ????}??
18. ???});??
19. ??}??
20. ?}??
21. }??
結果依次輸出,相當于順序執行各個任務。
你可以使用JDK自帶的監控工具來監控我們創建的線程數量,運行一個不終止的線程,創建指定量的線程,來觀察:
工具目錄:**C:\Program Files\Java\jdk1.6.0_06\bin\jconsole.exe**
運行程序做稍微修改:
Java代碼??
1. package?test;??
2. import?java.util.concurrent.ExecutorService;??
3. import?java.util.concurrent.Executors;??
4. public?class?ThreadPoolExecutorTest?{??
5. ?public?static?void?main(String[]?args)?{??
6. ??ExecutorService?singleThreadExecutor?=?Executors.newCachedThreadPool();??
7. ??for?(int?i?=?0;?i?100;?i++)?{??
8. ???final?int?index?=?i;??
9. ???singleThreadExecutor.execute(new?Runnable()?{??
10. ????public?void?run()?{??
11. ?????try?{??
12. ??????while(true)?{??
13. ???????System.out.println(index);??
14. ???????Thread.sleep(10?*?1000);??
15. ??????}??
16. ?????}?catch?(InterruptedException?e)?{??
17. ??????e.printStackTrace();??
18. ?????}??
19. ????}??
20. ???});??
21. ???try?{??
22. ????Thread.sleep(500);??
23. ???}?catch?(InterruptedException?e)?{??
24. ????e.printStackTrace();??
25. ???}??
26. ??}??
27. ?}??
28. }??
效果如下:
?
選擇我們運行的程序:

監控運行狀態
請您到ITEYE網站看 java小強 原創,謝謝!
[http://cuisuqiang.iteye.com/](http://cuisuqiang.iteye.com/)?!
自建博客地址:[http://www.javacui.com/](http://www.javacui.com/)?,內容與ITEYE同步!
- JVM
- 深入理解Java內存模型
- 深入理解Java內存模型(一)——基礎
- 深入理解Java內存模型(二)——重排序
- 深入理解Java內存模型(三)——順序一致性
- 深入理解Java內存模型(四)——volatile
- 深入理解Java內存模型(五)——鎖
- 深入理解Java內存模型(六)——final
- 深入理解Java內存模型(七)——總結
- Java內存模型
- Java內存模型2
- 堆內內存還是堆外內存?
- JVM內存配置詳解
- Java內存分配全面淺析
- 深入Java核心 Java內存分配原理精講
- jvm常量池
- JVM調優總結
- JVM調優總結(一)-- 一些概念
- JVM調優總結(二)-一些概念
- VM調優總結(三)-基本垃圾回收算法
- JVM調優總結(四)-垃圾回收面臨的問題
- JVM調優總結(五)-分代垃圾回收詳述1
- JVM調優總結(六)-分代垃圾回收詳述2
- JVM調優總結(七)-典型配置舉例1
- JVM調優總結(八)-典型配置舉例2
- JVM調優總結(九)-新一代的垃圾回收算法
- JVM調優總結(十)-調優方法
- 基礎
- Java 征途:行者的地圖
- Java程序員應該知道的10個面向對象理論
- Java泛型總結
- 序列化與反序列化
- 通過反編譯深入理解Java String及intern
- android 加固防止反編譯-重新打包
- volatile
- 正確使用 Volatile 變量
- 異常
- 深入理解java異常處理機制
- Java異常處理的10個最佳實踐
- Java異常處理手冊和最佳實踐
- Java提高篇——對象克隆(復制)
- Java中如何克隆集合——ArrayList和HashSet深拷貝
- Java中hashCode的作用
- Java提高篇之hashCode
- 常見正則表達式
- 類
- 理解java類加載器以及ClassLoader類
- 深入探討 Java 類加載器
- 類加載器的工作原理
- java反射
- 集合
- HashMap的工作原理
- ConcurrentHashMap之實現細節
- java.util.concurrent 之ConcurrentHashMap 源碼分析
- HashMap的實現原理和底層數據結構
- 線程
- 關于Java并發編程的總結和思考
- 40個Java多線程問題總結
- Java中的多線程你只要看這一篇就夠了
- Java多線程干貨系列(1):Java多線程基礎
- Java非阻塞算法簡介
- Java并發的四種風味:Thread、Executor、ForkJoin和Actor
- Java中不同的并發實現的性能比較
- JAVA CAS原理深度分析
- 多個線程之間共享數據的方式
- Java并發編程
- Java并發編程(1):可重入內置鎖
- Java并發編程(2):線程中斷(含代碼)
- Java并發編程(3):線程掛起、恢復與終止的正確方法(含代碼)
- Java并發編程(4):守護線程與線程阻塞的四種情況
- Java并發編程(5):volatile變量修飾符—意料之外的問題(含代碼)
- Java并發編程(6):Runnable和Thread實現多線程的區別(含代碼)
- Java并發編程(7):使用synchronized獲取互斥鎖的幾點說明
- Java并發編程(8):多線程環境中安全使用集合API(含代碼)
- Java并發編程(9):死鎖(含代碼)
- Java并發編程(10):使用wait/notify/notifyAll實現線程間通信的幾點重要說明
- java并發編程-II
- Java多線程基礎:進程和線程之由來
- Java并發編程:如何創建線程?
- Java并發編程:Thread類的使用
- Java并發編程:synchronized
- Java并發編程:Lock
- Java并發編程:volatile關鍵字解析
- Java并發編程:深入剖析ThreadLocal
- Java并發編程:CountDownLatch、CyclicBarrier和Semaphore
- Java并發編程:線程間協作的兩種方式:wait、notify、notifyAll和Condition
- Synchronized與Lock
- JVM底層又是如何實現synchronized的
- Java synchronized詳解
- synchronized 與 Lock 的那點事
- 深入研究 Java Synchronize 和 Lock 的區別與用法
- JAVA編程中的鎖機制詳解
- Java中的鎖
- TreadLocal
- 深入JDK源碼之ThreadLocal類
- 聊一聊ThreadLocal
- ThreadLocal
- ThreadLocal的內存泄露
- 多線程設計模式
- Java多線程編程中Future模式的詳解
- 原子操作(CAS)
- [譯]Java中Wait、Sleep和Yield方法的區別
- 線程池
- 如何合理地估算線程池大小?
- JAVA線程池中隊列與池大小的關系
- Java四種線程池的使用
- 深入理解Java之線程池
- java并發編程III
- Java 8并發工具包漫游指南
- 聊聊并發
- 聊聊并發(一)——深入分析Volatile的實現原理
- 聊聊并發(二)——Java SE1.6中的Synchronized
- 文件
- 網絡
- index
- 內存文章索引
- 基礎文章索引
- 線程文章索引
- 網絡文章索引
- IOC
- 設計模式文章索引
- 面試
- Java常量池詳解之一道比較蛋疼的面試題
- 近5年133個Java面試問題列表
- Java工程師成神之路
- Java字符串問題Top10
- 設計模式
- Java:單例模式的七種寫法
- Java 利用枚舉實現單例模式
- 常用jar
- HttpClient和HtmlUnit的比較總結
- IO
- NIO
- NIO入門
- 注解
- Java Annotation認知(包括框架圖、詳細介紹、示例說明)