码迷,mamicode.com
首页 > 其他好文 > 详细

使用ObjectInputStream和ObjectOutputStream注意问题

时间:2015-04-04 18:19:44      阅读:258      评论:0      收藏:0      [点我收藏+]

标签:

1、对象序列化,类实现Serializable接口

不需要序列化的属性,使用transient声明

2、使用套接字流在主机之间传递对象注意问题:

学习自:Socket同时使用ObjectInputStream和ObjectOutputStream传输序列化对象时的顺序

ObjectInputStream与ObjectOutputStream的顺序问题

在网络通讯中,主机与客户端若使用ObjectInputStream与ObjectOutputStream建立对象通讯,必须注重声明此两个对象的顺序。
如:
主机端先建立ObjectInputStream后建立ObjectOutputStream,则对应地客户端要先建立ObjectOutputStream后建立ObjectInputStream,否则会造成两方互相等待数据而导致死锁。
原因是建立ObjectInputStream对象是需要先接收一定的header数据,接收到这些数据之前会处于阻塞状态。

public ObjectInputStream(InputStream in) throws IOException的官方API显示:Creates an ObjectInputStream that reads from the specified InputStream. A serialization stream header is read from the stream and verified. This constructor will block until the corresponding ObjectOutputStream has written and flushed the header. 

在创建ObjectInputStream对象时会检查ObjectOutputStream所传过来了头信息,如果没有信息将一直会阻塞

使用ObjectInputStream和ObjectOutputStream注意问题

标签:

原文地址:http://www.cnblogs.com/vegg117/p/4392463.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!