Я новичок в программировании Socket на Java и пытался понять, не подходит ли этот код ниже. Мой вопрос:
Могу ли я иметь несколько клиентов в каждом потоке, пытающихся подключиться к экземпляру сервера в той же программе, и ожидать, что сервер будет читать и записывать данные с изоляцией между клиентами?
public class Client extends Thread
{
...
void run()
{
Socket socket = new Socket("localhost", 1234);
doIO(socket);
}
}
public class Server extends Thread
{
...
void run()
{
// serverSocket on "localhost", 1234
Socket clientSock = serverSocket.accept();
executor.execute(new ClientWorker(clientSock));
}
}
Теперь можно ли несколько экземпляров клиента на разных потоках пытаться подключиться к одному и тому же порту текущего компьютера?
Например,
Server s = new Server("localhost", 1234);
s.start();
Client[] c = new Client[10];
for (int i = 0; i < c.length; ++i)
{
c.start();
}