我没有回答为什么第四个连接挂起,除了说这里是一个有效的代码版本…
public class Test {
public static void main(String[] args) throws Exception {
ServerSocket listen = new ServerSocket(9999);
ExecutorService threadPool = Executors.newFixedThreadPool(3);
while(true) {
Socket client = null;
try {
client = listen.accept();
} catch(IOException e) {
System.err.println(e);
}
System.out.println("New connection from client: " +
client.getInetAddress().getHostAddress() + "\n"
);
threadPool.execute(new ConnectionHandler(client));
}
}
}
class ConnectionHandler implements Runnable {
private Socket client;
public ConnectionHandler(Socket client) {
this.client = client;
}
@Override
public void run() {
try(BufferedReader in = new BufferedReader(new InputStreamReader(client.getInputStream()));
BufferedWriter out = new BufferedWriter(new OutputStreamWriter(client.getOutputStream()))) {
String input;
while(true) {
input = in.readLine();
if(input == null)
break;
out.write(input);
out.newLine();
out.flush();
}
} catch(IOException e) {
System.err.println("Error from socket IO.");
}
try {
client.close();
} catch(IOException e) {
System.err.println("Error when closing socket.");
}
System.out.println("Client " + client.getInetAddress().getHostAddress() +
" closed connection.\n");
}
}
我用telnet连接,回复了一些字符并断开连接.我这样做了5次.
New connection from client: 0:0:0:0:0:0:0:1
Client 0:0:0:0:0:0:0:1 closed connection.
New connection from client: 0:0:0:0:0:0:0:1
Client 0:0:0:0:0:0:0:1 closed connection.
New connection from client: 0:0:0:0:0:0:0:1
Client 0:0:0:0:0:0:0:1 closed connection.
New connection from client: 0:0:0:0:0:0:0:1
Client 0:0:0:0:0:0:0:1 closed connection.
New connection from client: 0:0:0:0:0:0:0:1
Client 0:0:0:0:0:0:0:1 closed connection.
唯一的区别是问题中的代码有…
input = readLine();
在哪里我需要改变它
input = in.readLine();
有效.我想知道在未发布到问题的代码中是否包含静态变量或其他类型的恶作剧.