我正在构建一个简单的Java服务器,它同时使用两个ServerSocket实例同时侦听两个端口上的客户端请求。以下是Server的代码:
import java.io.PrintWriter;
import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket;
class Socket1 implements Runnable
{
public void run()
{
try
{
ServerSocket serverSock=new ServerSocket(5000);
while(true)
{
Socket sock=serverSock.accept();
PrintWriter writer=new PrintWriter(sock.getOutputStream());
String text="Welcome to Port 5000";
writer.println(text);
}
}
catch(Exception e)
{
System.out.println("Error");
}
}
}
class Socket2 implements Runnable
{
public void run()
{
try
{
ServerSocket serverSock=new ServerSocket(3000);
while(true)
{
Socket sock=serverSock.accept();
PrintWriter writer=new PrintWriter(sock.getOutputStream());
String text="Welcome to Port 3000";
writer.println(text);
}
}
catch(Exception e)
{
System.out.println("Error");
}
}
}
public class Server
{
public static void main(String[] args)
{
Socket1 s1=new Socket1();
Socket2 s2=new Socket2();
Thread t1=new Thread(s1);
Thread t2=new Thread(s2);
t1.start();
t2.start();
}
}
现在Client1的代码:
import java.io.InputStreamReader;
import java.io.BufferedReader;
import java.net.Socket;
public class Client1
{
public static void main(String[] args)
{
try
{
Socket s=new Socket("127.0.0.1", 5000);
InputStreamReader streamReader=new InputStreamReader(s.getInputStream());
BufferedReader reader=new BufferedReader(streamReader);
String text=reader.readLine();
System.out.println(text);
reader.close();
}
catch(Exception e)
{
System.out.println("Error");
}
}
}
Client2包含与Client1相同的代码,唯一的区别是它尝试连接到端口3000。 现在,我首先使用命令提示符执行Server.java。当服务器阻塞时,我打开两个单独的命令提示并在一个命令提示符上执行Client1.java,在另一个命令提示符上执行Client2.java。但是,两个客户端都进入阻塞状态,我没有输出。不知道怎么解决这个问题?
答案 0 :(得分:2)
默认情况下,PrintWriter是缓冲的。在writer.flush()
之后添加close()
(甚至更好writer.println()
,因为您不再使用该流)。
答案 1 :(得分:0)
您可能会从此link获得一些提示,这些提示可以回答与您类似的问题。感谢。