具有多个积压的服务器套接字如何工作?

Hap*_*per 2 java sockets network-programming serversocket

我是套接字编程的新手,我在理解 serversocket 时遇到了问题。假设我们创建了一个这样的 serversocket:

loadbalancerSocket = new ServerSocket(port, 20);
connection = loadbalancerSocket.accept();
Run Code Online (Sandbox Code Playgroud)

然后在一些东西之后,在它的缓冲区中写一些东西:

BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(connection.getOutputStream()));
                writer.write("Hello!");
                writer.flush();
                writer.close();
Run Code Online (Sandbox Code Playgroud)

我的问题是:连接如何理解哪个客户端应该得到服务器的响应?我们的积压是 20 ,并且 20 个客户端可以同时连接到服务器套接字(据我了解)。

Zab*_*ula 5

在您的示例中,第一个连接的客户端获得响应。backlog 参数并不意味着可以并行连接的客户端数量。它是等待接受连接的最大客户端数。

ServerSocket未连接到任何特定的客户端。连接的套接字是从 返回的套接字accept()。如果要并行处理多个客户端,则必须accept()多次调用并分别处理连接。例如,您可以为每个连接创建一个特殊线程。

accept()通常在循环中调用,并且从返回的新创建的连接套接字accept()通常传递给负责特定客户端的处理程序。