jdk1.4 構建 java多線程,併發設計框架 使用列子(二)

 把讀取的數據流,獲取數據流後,
1啓動一個子線程,讀取數據,把數據放入緩衝多線程併發隊列
2把數據交給處理流數據對象,使得讀取數據與處理數據分離
  1. import java.io.*;
  2. import java.net.Socket;
  3. import java.net.InetSocketAddress;
  4. import java.nio.ByteBuffer;
  5. /**
  6.  * 獲取相關數據流.
  7.  * 把讀取的數據流,發送給處理數據流的對象ProcessRequestData.
  8.  * @author guishuanglin 2008-11-3
  9.  * 
  10.  */
  11. public class ProcessRequest implements Runnable {
  12.     //ByteArrayOutputStream
  13.     private ConcurrentQueue cQueue;
  14.     private Socket socket;
  15.     private Class clientClass;
  16.     private int requestCount;
  17.     private int cacheByte = 1024;
  18.     /**
  19.      * @param ss
  20.      * @param requestNum
  21.      */
  22.     public ProcessRequest(Socket st, int requestCount,int cacheByte,Class clientClass) {
  23.         socket = st;
  24.         this.requestCount= requestCount;
  25.         this.clientClass = clientClass;
  26.         this.cacheByte   = cacheByte;
  27.         CreateCacheQueue();
  28.     }
  29.     public void run() {
  30.         //啓動一個子線程,讀取數據,把數據放入緩衝隊列
  31.         new Thread(new ProcessRequestStream(socket,requestCount,cacheByte,cQueue)).start();
  32.         // 獲取數據流後,把數據交給處理流數據對象,使得讀取數據與處理數據分離.
  33.         String s = socket.getInetAddress().getHostAddress();
  34.         new Thread(new ProcessRequestData(requestCount,s,clientClass,cQueue)).start();
  35.         //
  36.         ReleaseResource();
  37.     }
  38.     /**
  39.      * 創建客戶數據緩衝隊
  40.      * @date 2008-11-3
  41.      */
  42.     public void CreateCacheQueue(){
  43.         this.cQueue = new ConcurrentQueue(1024,String.valueOf(requestCount));
  44.     }
  45.     
  46.     public void ReleaseResource() {
  47.         socket=null;
  48.         clientClass=null;
  49.         cQueue   = null;
  50.     }
  51. }

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章