首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

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

2012-08-21 
分布式应用中java对象序列化问题?██?在分布式应用中,通常会以RMI协议作为分布式服务的对象传输协议,在不同

分布式应用中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   第三点领教了!

热点排行