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

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

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

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

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

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

ArrayList result = new ArrayList();
//.......

return result.subList(0,5);

  这样返回给容器,容器在处理返回结果的序列化的时候会抛出异常,原因很简单,subList 返回的结果是 SubList类型的而sublist没有实现 Serializable接口

  ◢3 如果函数返回对象是list,而这个list会随之序列化,那list中的对象的属性如果存在相互引用的话,则list在序列化的时候会出问题,出现死循环。

                        

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

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

猜你喜欢

转载自mozhenghua.iteye.com/blog/1121176