我在写一个Socket服务器时,使用了BufferedReader.readLine()的方法来读取消息,客户端用BufferedWriter.write()来写数据,但是却出现了以下情况:
我的服务器接收代码为:
try{
in = new BufferedReader(new InputStreamReader(socket.getInputStream()));//Java流读写
out = new BufferedWriter(new OutputStreamWriter(socket.getOutputStream()));
while(true){
if(in.ready()){
String msg=in.readLine();
System.out.println(socket.getPort()+"-发来消息:\n"+msg);
}
}
}catch(Exception e){
e.printStackTrace();
return ;
}
客户端发送代码为:
try{
BufferedWriter out = new BufferedWriter(new OutputStreamWriter(socket.getOutputStream()));
out.write("FFi");
}catch (Exception e){
e.printStackTrace();
}
可以注意到我发送的是"FFi"这个单元,但是在服务器接收到的却是"FFiFFiFFi",而且是在Scoket断开时一次性刷出来的。
我找了很久的原因,后来才知道readline()函数其实自带了一个阻塞....也就是说in.readline()实际上收到第一次"FFi"之后,依旧堵塞着,这条信息一直存在缓存里,下面的System.out.println()语句压根没执行到,直到Socket断开,强制清缓存的时候,readline()不再阻塞。
那应该怎么办呢?
其实readline()读取的结束标识符是"\n",所以客户端代码改成如下形式就好了:
try{
BufferedWriter out = new BufferedWriter(new OutputStreamWriter(socket.getOutputStream()));
out.write("FFi\n");//修改这里
}catch (Exception e){
e.printStackTrace();
}
效果如图所示: