读书人

分布式应用中java对象序列化有关问题

发布时间: 2012-08-21 13:00:21 作者: rapoo

分布式应用中java对象序列化问题

?

?在分布式应用中,通常会以RMI协议作为分布式服务的对象传输协议,在不同服务器之间传输对象之前需要先将对象序列化,java底层sdk中已经将对象的序列化机制实现了。几乎可以兼容所有java类型的序列化(Serialize)

?

在实际应用中需要注意以下几点:

?

?

? 1 需要序列化的对象需要实现java.io.Serializable 接口,如果在传输对象的对象的类型没有实现这个接口的话,运行时通常会抛出异常。

?

? 通常为了避免这个问题的发生的办法是,在写代码的时候在参数申明上就申明为java.io.Serializable的对象类型。这样类似的错误在代码编译期就能发现。

?

? 2 在写EJB的实现类的的过程中,函数返回值如果是一个list的话,那在返回结果的时候不能是

类似返回的list中存放着上图的User对象,而每个User对象中都有一个Friend属性,如果在列表中前一的两个User对象他们互为朋友的话,那这整个对象将无法序列化。

解决办法是确定User对象中的Friend属性是否真的需要序列化,如果没有必要序列化的话,就在定义Friend属性的地方加上transient 这个关键字,告诉java虚拟机在序列化操作的时候不对该属性进行序列化操作。

?

?

1 楼 jstudio 2011-09-16 瓜哥分析得很好,学习了~ 2 楼 bushyou 2011-09-19 第三点领教了!

读书人网 >软件架构设计

热点推荐