我需要在
Java中建立一个工作池,每个工作人员都有自己的连接套接字;当工作线程运行时,它使用套接字,但保持打开以便稍后重用.我们决定采用这种方法,因为与ad-hoc基础上创建,连接和销毁套接字有关的开销需要太多的开销,所以我们需要一种方法,通过这种方法,一组工作人员可以使用它们的套接字连接进行初始化,准备同时保持套接字资源从其他线程安全(套接字不是线程安全的),所以我们需要这些行的东西…
public class SocketTask implements Runnable {
Socket socket;
public SocketTask(){
//create + connect socket here
}
public void run(){
//use socket here
}
}
在应用程序启动时,我们要初始化工作人员,希望也可以通过socket连接进行初始化
MyWorkerPool pool = new MyWorkerPool();
for( int i = 0; i < 100; i++)
pool.addWorker( new WorkerThread());
当应用程序请求工作时,我们将任务发送到工作池以立即执行…
pool.queueWork( new SocketTask(..));
更新了工作代码
根据Gray和jontejj的有用评论,我已经得到以下代码:
SocketTask
public class SocketTask implements Runnable {
private String workDetails;
private static final ThreadLocal threadLocal =
new ThreadLocal(){
@Override
protected Socket initialValue(){
return new Socket();
}
};
public SocketTask(String details){
this.workDetails = details;
}
public void run(){
Socket s = getSocket(); //gets from threadlocal
//send data on socket based on workDetails, etc.
}
public static Socket getSocket(){
return threadLocal.get();
}
}
ExecutorService的
ExecutorService threadPool =
Executors.newFixedThreadPool(5, Executors.defaultThreadFactory());
int tasks = 15;
for( int i = 1; i <= tasks; i++){
threadPool.execute(new SocketTask("foobar-" + i));
}
我喜欢这种方法有几个原因
>套接字是可用于运行任务的本地对象(通过ThreadLocal),可消除并发问题.
>套接字创建一次并保持开放,重用
当新任务排队时,消除套接字对象创建/销毁开销.