jdk1.4 构建 java多线程,并发设计框架 使用列子(二)

来源:互联网 发布:php获取cookie值 编辑:程序博客网 时间:2024/05/16 17:50
把读取的数据流,获取数据流后,
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. }