java.io.StreamCorruptedException: invalid stream header: 73720015

事故代码:

服务端:每次接收由套接字传来的Message对象,并将对象打印。

while (true){            
                ObjectInputStream ois = new ObjectInputStream(socket.getInputStream());
                message=(Message) ois.readObject();
                System.out.println(message);            
}

客户端:输入消息发送给服务端。

ObjectOutputStream oos = new ObjectOutputStream(socket.getOutputStream());

while (true){               
                System.out.println("请输入要发送的信息");
                String content = scanner.next();               
                oos.writeObject(new Message(content));//问题:这里由同一个oos进行写入
}

问题原理:

每次new ObjectOutputStream()的时候都会调用writeStreamHeader()方法向写入4个字节的StreamHeader,用来标记是对象流。由同一个ObjectOutPutStream发送多个对象时只会出现1个StreamHeader,这意味着程序无法识别流中对象的数目。

ObjectOutStream构造方法:

public ObjectOutputStream(OutputStream out) throws IOException {  
        verifySubclass();  
        bout = new BlockDataOutputStream(out);  
        handles = new HandleTable(10, (float) 3.00);  
        subs = new ReplaceTable(10, (float) 3.00);  
        enableOverride = false;  
        writeStreamHeader();  
        bout.setBlockDataMode(true);  
        if (extendedDebugInfo) {  
            debugInfoStack = new DebugTraceInfoStack();  
        } else {  
            debugInfoStack = null;  
        }  
    }  

解决方案:

在每次writeObject的时候都重新new 一个ObjectOutPutStream对象。

客户端:

 while (true){
                //发送信息
           System.out.println("请输入要发送的信息");
           String content = scanner.next();
           new ObjectOutputStream(socket.getOutputStream()).writeObject(new Message(content));//每一个对象仅对应一次write操作
          //oos.writeObject();
}

你可能感兴趣的:(bug日志,java,linux,开发语言)