山狮 2015-05-27 04:22 采纳率: 50%
浏览 1602
已采纳

java网络编程中IO数据输入输出阻塞

服务端代码如下:
public class Server {
  public static void main(String[] args) throws IOException {
    ServerSocket ss = new ServerSocket(30000);
    Socket socket = ss.accept();
    PrintStream ps = new PrintStream(socket.getOutputStream());
    ps.println("服务器第一行数据"); //1
    ps.println("服务器第二行数据"); //2
    ocket.shutdownOutput(); //3
    //下面语句将输出false
    System.out.println(socket.isClosed());
    Scanner scan = new Scanner(socket.getInputStream());
    BufferedReader br = new BufferedReader(new     InputStreamReader(socket.getInputStream()));
    //为什么只得到客户端第一条数据
    if(scan.hasNext()) {
      System.out.println(scan.nextLine());
    }
    //为什么此处得不到数据
     while(br.readLine() != null) {
      System.out.println(br.readLine());
    }
    scan.close();
    br.close();
    socket.close();
    ss.close();
    }
}
客户端代码如下:
public class Client {
  public static void main(String[] args) throws IOException {
    Socket s = new Socket("localhost", 30000);
    Scanner scan = new Scanner(s.getInputStream());
    // 为什么只能得到服务端第一条数据
    if (scan.hasNextLine()) {
      System.out.println(scan.nextLine());
    }
    PrintStream ps = new PrintStream(s.getOutputStream());
    ps.println("客户端的第一行数据");
    ps.println("客户端的第二行数据");
    ps.close();
    scan.close();
    s.close();
  }
}
服务端运行结果:
false
客户端的第一行数据
客户端运行结果:
服务器第一行数据
如上述所示,服务端在 //1,//2处已经将数据输出到socket输出流了,在//3处才关闭输出功能,为什在客户端得到的数据只能显示一条
同样,客户端输出了两条数据,在服务端关闭输出,输入功能应该不收影响,为什么也只能得到一条数据。

  • 写回答

3条回答

  • danielinbiti 2015-05-27 04:29
    关注
     if(scan.hasNext()) {
          System.out.println(scan.nextLine());
        }
            照你的意思是不是应该是while,而不是if
            while(scan.hasNext()) {
          System.out.println(scan.nextLine());
        }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?
  • ¥15 乘性高斯噪声在深度学习网络中的应用
  • ¥15 运筹学排序问题中的在线排序
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛