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