}
}
这样的服务器代码很简单,理论上也是正确的,但是在实现的环境中却很糟糕,因为它每次只能处理一个请求,如果每个请求的耗时过长,后面的请求会长时间等待或者超时错误。
于是乎,出现了下面这种写法:
###### 2、每个请求分配一个线程的服务器
package com.zhy.concurrency.executors;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
/**
-
为每个请求分配一个线程
-
@author zhy
*/
public class TaskPreThreadServer
{
public static void main(String[] args) throws IOException
{
ServerSocket server = new ServerSocket(8811);
while (true)
{
final Socket client = server.accept();
new Thread()
{
public void run()
{
handleReq(client);
};
}.start();
}
}
protected static void handleReq(Socket client)
{
}
}
为每一个请求开辟一个线程,首先我得承认我也经常用这样的写法~但是我们还是要吐槽下