成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Java之線程池簡單實現

開發 后端
在面向對象編程中,創建和銷毀對象是很費時間的,因為創建一個對象要獲取內存資源或者其它更多資源。在Java中更是如此,虛擬機將試圖跟蹤每一個對象, 以便能夠在對象銷毀后進行垃圾回收。如何利用已有對象來服務就是一個需要解決的關鍵問題,其實這就是一些"池化資源"技術產生的原因。

以前做的東西,實現一個簡單的多線程機制,開始之前,現說說原理性的東西吧,下面是我在ibm開發者上搜到的內容

線程池的技術背景

在面向對象編程中,創建和銷毀對象是很費時間的,因為創建一個對象要獲取內存資源或者其它更多資源。在Java中更是如此,虛擬機將試圖跟蹤每一個對象, 以便能夠在對象銷毀后進行垃圾回收。所以提高服務程序效率的一個手段就是盡可能減少創建和銷毀對象的次數,特別是一些很耗資源的對象創建和銷毀。如何利用 已有對象來服務就是一個需要解決的關鍵問題,其實這就是一些"池化資源"技術產生的原因。

多線程技術主要解決處理器單元內多個線程執行的問題,它可以顯著減少處理器單元的閑置時間,增加處理器單元的吞吐能力。但如果對多線程應用不當,會增加對單個任務的處理時間??梢耘e一個簡單的例子:

假設在一臺服務器完成一項任務的時間為T

◆  T1 創建線程的時間

◆ T2 在線程中執行任務的時間,包括線程間同步所需時間

◆ T3 線程銷毀的時間

顯然T = T1+T2+T3。注意這是一個極度簡化的假設。

可以看出T1,T3是多線程本身的帶來的開銷,我們渴望減少T1,T3所用的時間,從而減少T的時間。但一些線程的使用者并沒有注意到 這一點,所以在程序中頻繁的創建或銷毀線程,這導致T1和T3在T中占有相當比例。顯然這是突出了線程的弱點(T1,T3),而不是優點(并發性)。

線程池技術正是關注如何縮短或調整T1,T3時間的技術,從而提高服務器程序性能的。它把T1,T3分別安排在服務器程序的啟動和結束的時間段或者一些空閑的時間段,這樣在服務器程序處理客戶請求時,不會有T1,T3的開銷了。

線程池不僅調整T1,T3產生的時間段,而且它還顯著減少了創建線程的數目。在看一個例子:

假設一個服務器一天要處理50000個請求,并且每個請求需要一個單獨的線程完成。我們比較利用線程池技術和不利于線程池技術的服務器 處理這些請求時所產生的線程總數。在線程池中,線程數一般是固定的,所以產生線程總數不會超過線程池中線程的數目或者上限(以下簡稱線程池尺寸),而如果 服務器不利用線程池來處理這些請求則線程總數為50000。一般線程池尺寸是遠小于50000。所以利用線程池的服務器程序不會為了創建50000而在處 理請求時浪費時間,從而提高效率。

這些都是假設,不能充分說明問題,下面我將討論線程池的簡單實現并對該程序進行對比測試,以說明線程技術優點及應用領域。

一般一個簡單線程池至少包含下列組成部分

◆ 線程池管理器(ThreadPoolManager):用于創建并管理線程池

◆ 工作線程(WorkThread): 線程池中線程

◆ 任務接口(Task):每個任務必須實現的接口,以供工作線程調度任務的執行。

◆ 任務隊列:用于存放沒有處理的任務。提供一種緩沖機制。

線程池管理器至少有下列功能:創建線程池,銷毀線程池,添加新任務。下面就是小弟的實現,還是歡迎拍磚哈:

  1. public class ThreadPoolManager {  
  2.     private static ThreadPoolManager instance = null;  
  3.     private List<Upload> taskQueue = Collections.synchronizedList(new LinkedList<Upload>());//任務隊列  
  4.     private WorkThread[] workQueue ;    //工作線程(真正執行任務的線程)  
  5.     private static int worker_num = 5;    //工作線程數量(默認工作線程數量是5)  
  6.     private static int worker_count = 0;  
  7.       
  8.     private ThreadPoolManager(){  
  9.         this(5);  
  10.     }  
  11.     private ThreadPoolManager(int num){  
  12.         worker_num = num;  
  13.         workQueue = new WorkThread[worker_num];  
  14.         for(int i=0;i<worker_num;i++){  
  15.             workQueue[i] = new WorkThread(i);  
  16.         }  
  17.     }  
  18.       
  19.     public static synchronized ThreadPoolManager getInstance(){  
  20.         if(instance==null)  
  21.             instance = new ThreadPoolManager();  
  22.         return instance;  
  23.     }  
  24.       
  25.     public void addTask(Upload task){  
  26.         //對任務隊列的操作要上鎖  
  27.         synchronized (taskQueue) {  
  28.             if(task!=null){  
  29.                 taskQueue.add(task);  
  30.                 taskQueue.notifyAll();  
  31.                 System.out.println("task id "+task.getInfo() + " submit!");  
  32.             }  
  33.                   
  34.         }  
  35.     }  
  36.       
  37.     public void BatchAddTask(Upload[] tasks){  
  38.         //對任務隊列的修改操作要上鎖  
  39.         synchronized (taskQueue) {  
  40.             for(Upload e:tasks){  
  41.                 if(e!=null){  
  42.                     taskQueue.add(e);  
  43.                     taskQueue.notifyAll();  
  44.                     System.out.println("task id "+e.getInfo() + " submit!");  
  45.                 }  
  46.             }          
  47.         }  
  48.     }  
  49.       
  50.     public void destory(){  
  51.         System.out.println("pool begins to destory ...");  
  52.         for(int i = 0;i<worker_num;i++){  
  53.             workQueue[i].stopThread();  
  54.             workQueue[i] = null;  
  55.         }  
  56.         //對任務隊列的操作要上鎖  
  57.         synchronized (taskQueue) {  
  58.             taskQueue.clear();  
  59.         }  
  60.           
  61.         System.out.println("pool ends to destory ...");  
  62.     }  
  63.       
  64.     private class WorkThread extends Thread{  
  65.         private int taksId ;  
  66.         private boolean isRuning = true;  
  67.         private boolean isWaiting = false;  
  68.           
  69.           
  70.            
  71.         public WorkThread(int taskId){  
  72.             this.taksId= taskId;  
  73.             this.start();  
  74.         }  
  75.           
  76.         public boolean isWaiting(){  
  77.             return isWaiting;  
  78.         }  
  79.         // 如果任務進行中時,不能立刻終止線程,需要等待任務完成之后檢測到isRuning為false的時候,退出run()方法  
  80.         public void stopThread(){  
  81.             isRuning = false;  
  82.         }  
  83.           
  84.         @Override 
  85.         public void run() {  
  86.             while(isRuning){  
  87.                 Upload temp = null;  
  88.                 //對任務隊列的操作要上鎖  
  89.                 synchronized (taskQueue) {  
  90.                     //任務隊列為空,等待新的任務加入  
  91.                     while(isRuning&&taskQueue.isEmpty()){  
  92.                         try {  
  93.                             taskQueue.wait(20);  
  94.                         } catch (InterruptedException e) {  
  95.                             System.out.println("InterruptedException occre...");  
  96.                             e.printStackTrace();  
  97.                         }  
  98.                     }  
  99.                     if(isRuning)  
  100.                         temp = taskQueue.remove(0);  
  101.                 }  
  102.                 //當等待新任務加入時候,終止線程(調用stopThread函數)造成 temp = null  
  103.                 if(temp!=null){  
  104.                     System.out.println("task info: "+temp.getInfo()+ " is begining");  
  105.                     isWaiting = false;  
  106.                     temp.uploadPic();  
  107.                     isWaiting = true;  
  108.                     System.out.println("task info: "+temp.getInfo()+ " is finished");  
  109.                 }      
  110.             }  
  111.         }  
  112.     }  

然后定義任務接口(Task):這里我定義的是上傳圖片的功能接口(這里用抽象類或者接口隨你自己)。

  1. public abstract class Upload {  
  2.     protected String info;  
  3.     abstract boolean uploadPic();  
  4.     public String getInfo(){  
  5.         return info;  
  6.     }  

然后定義具體任務類:我這里簡單,讓它睡眠2s。當然你也可以定義很多實現Upload的任務類。

  1. public class TaskUpload extends Upload {  
  2.       
  3.     public TaskUpload(String info){  
  4.         this.info = info;  
  5.     }  
  6.     public String getInfo(){  
  7.         return info;  
  8.     }  
  9.     @Override 
  10.     public boolean uploadPic()  {  
  11.         // TODO Auto-generated method stub  
  12.         System.out.println(info+"sleep begin ....");  
  13.         try {  
  14.             Thread.sleep(2000);  
  15.         } catch (InterruptedException e) {  
  16.             // TODO Auto-generated catch block  
  17.             e.printStackTrace();  
  18.         }  
  19.         System.out.println(info+"sleep end ....");  
  20.         return false;  
  21.     }  

***,測試這個簡單的線程池:

  1. public class ThreadPoolManagerTest {  
  2.  
  3.  
  4.     public static void main(String[] args) {  
  5.         // TODO Auto-generated method stub  
  6.         Upload[] tasks = createBatchTask(7);  
  7.         ThreadPoolManager pool = ThreadPoolManager.getInstance();  
  8.         pool.BatchAddTask(tasks);  
  9.         pool.destory();  
  10.     }  
  11.     private static Upload[] createBatchTask(int n){  
  12.         Upload[] tasks = new TaskUpload[n];  
  13.         for(int i = 0;i<n ;i++ ){  
  14.             tasks[i] = new TaskUpload("task id is "+ i);  
  15.         }  
  16.         return tasks;  
  17.     }  

線程池技術適用范圍及應注意的問題

線程池的應用范圍:

1、需要大量的線程來完成任務,且完成任務的時間比較短。 WEB服務器完成網頁請求這樣的任務,使用線程池技術是非常合適的。因為單個任務小,而任務數量巨大,你可以想象一個熱門網站的點擊次數。 但對于長時間的任務,比如一個Telnet連接請求,線程池的優點就不明顯了。因為Telnet會話時間比線程的創建時間大多了。

2、對性能要求苛刻的應用,比如要求服務器迅速相應客戶請求。

3、接受突發性的大量請求,但不至于使服務器因此產生大量線程的應用。突發性大量客戶請求,在沒有線程池情況下,將產生大量線程,雖然理論上大部分操作系統線程數目***值不是問題,短時間內產生大量線程可能使內存到達極限,并出現"OutOfMemory"的錯誤。

原文鏈接:http://www.cnblogs.com/slider/archive/2012/01/16/2323895.html

【編輯推薦】

  1. Java回調函數的理解
  2. Java路線圖:甲骨文的兩年計劃
  3. Java 8將支持無符號整型
  4. 深入研究Java虛擬機的類加載機制
  5. Swing多線程編碼過程中的誤區
責任編輯:林師授 來源: slider的博客
相關推薦

2020-09-04 10:29:47

Java線程池并發

2013-05-23 15:59:00

線程池

2023-06-07 13:49:00

多線程編程C#

2021-09-11 07:32:15

Java線程線程池

2020-12-10 08:24:40

線程池線程方法

2018-10-31 15:54:47

Java線程池源碼

2020-03-05 15:34:16

線程池C語言局域網

2012-05-15 02:18:31

Java線程池

2020-10-19 10:01:12

Nodejs線程池設計

2012-02-29 13:26:20

Java

2024-01-29 15:54:41

Java線程池公平鎖

2021-05-26 11:30:24

Java線程池代碼

2023-08-02 08:03:08

Python線程池

2015-08-20 09:17:36

Java線程池

2020-11-25 11:33:47

Java線程技術

2023-05-19 08:01:24

Key消費場景

2024-05-06 11:19:20

內存池計算機編程

2013-06-08 13:07:23

Java線程池調度器

2021-09-11 15:26:23

Java多線程線程池

2023-11-22 08:37:40

Java線程池
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 91高清在线| 精品欧美乱码久久久久久 | 天天精品在线 | 亚洲免费在线视频 | 九九九国产 | 毛片大全| 国产毛片毛片 | 国产成人精品午夜视频免费 | 亚洲欧美激情精品一区二区 | 婷婷综合色 | 欧美日韩一区二区三区视频 | 综合久久综合久久 | 中国av在线免费观看 | 成人一区二区视频 | 午夜一区二区三区视频 | 亚洲色综合 | 国产一区中文 | 中文字幕在线中文 | 天天曰天天曰 | 99视频免费播放 | 99re视频| www.黄色片视频 | 51ⅴ精品国产91久久久久久 | 日韩精品一区二 | 久久久99精品免费观看 | 玖玖免费 | 欧美精品一区在线 | 国产在线一区二区三区 | 亚洲精品久久久一区二区三区 | 99精品一级欧美片免费播放 | 天堂av影院 | 美女天堂在线 | 欧美日韩一二区 | 久久久久久中文字幕 | 91精品国产91久久久久久三级 | 日本福利视频免费观看 | 狠狠爱视频 | 亚洲精品在线免费看 | а_天堂中文最新版地址 | 亚洲一区毛片 | 亚洲精品视频在线观看免费 |