赞
踩
首先看一个dubbo调用场景:
测试一:使用dubbo协议,没有配置系列化方式(缺省使用hessian2)
(1)如果此时将B应用中Hello对象添加一个参数,升级二方包,并B应用重新发布,A应用保持不变
这时候问题来了,这时候A调用B能正常调用吗? 答案是可以的
(2)将B应用中的serialVersionUID删除掉,重新打包发布
此时,通过A调用B也是正常的
测试二:将B应用中dubbo的协议的系列化方式修改为java
(1)如果此时将B应用中Hello对象添加一个参数,升级二方包,并B应用重新发布,A应用保持不变
这时候问题来了,这时候A调用B能正常调用吗? 答案是可以的
(2)将B应用中的serialVersionUID删除掉,重新编译打包发布
此时,通过A调用B报错
我们从dubbo官网上可以看到这样一个参数介绍:(http://dubbo.apache.org/zh-cn/docs/user/references/xml/dubbo-protocol.html)
从上面的测试中发现,hessian2可以兼容同一对象的不同版本,这可能是系列化实现方式跟java不一样。查阅一些博客发现这样描述
hessian在反序列化的时候,是将对象所有属性取出来,存放在一个map中 key = 属性名 value是反序列类
一般情况下,实现Serializable接口会默认的生成一个 private static final long serialVersionUID ,java在反系列化的时候会将字节流中的serialVersionUID与本地的serialVersionUID作对比,如果一直则说明是同一个对象,就可以反序列化,否则会出现版本不一致的异常。
隐式:
隐式就是不声明serialVersionUID,那么每次重新编译的时候calss会自动生成一个serialVersionUID做为版本比较使用,在这种场景下,只有同一次编译的calss文件serialVersionUID才相同
显式:
就是在类文件中声明一个serialVersionUID,不改变这个值,无论编译多少次,都可以进行系列化和反系列化操作。
结论:
如果使用java系列化的方式,我们尽可能的显示实现一个serialVersionUID
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。