创建ObjectInputStream后无法看到打印消息

时间:2013-08-04 07:12:27

标签: java

我编写了以下程序。你可以看到我在创建ObjectInputStream对象之后放了一条打印消息。我有一个在端口9090上打开的服务器。正如你从上面的netstat消息中看到的那样

sudo netstat -al | grep 9090
tcp6       0      0 [::]:9090               [::]:*                  LISTEN   

我不知道为什么屏幕上会显示打印消息。

import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.lang.ClassNotFoundException;
import java.net.InetAddress;
import java.net.Socket;
import java.net.UnknownHostException;

public class MyClient {    
    public static void main(String[] args) {
        int count = 0;
        try {
            /*
             * Create a connection to the server socket on the server application
             */
             InetAddress address = InetAddress.getByName("localhost");
             Socket socket = new Socket(address, 9090);

            /*
             * Read and display the response message sent by server application
             */
            ObjectInputStream ois = new ObjectInputStream(socket.getInputStream());
            System.out.println("Created client socket and Input Stream Reader");
            while (true) {
                if (count < 1000) {
                    String message = (String) ois.readObject();
                    System.out.println("OFMessage: " + message);
                    count++;
                } else {
                    break;
                }
            }
            ois.close();
        } catch (UnknownHostException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

1 个答案:

答案 0 :(得分:2)

ObjectInputStream的构造函数从流中读取 - 它基本上读取了头信息。

因此,如果您正在与之交谈的服务器没有任何数据,那么您的程序将只是坐在那里,等待实际写入标题。

如果在运行此代码时在调试器中点击中断,我认为您会发现堆栈跟踪包含ObjectInputStream.readStreamHeader