类修改后需要重新计算serialVersionUID值

来源:互联网 发布:殷保华黄金模式源码 编辑:程序博客网 时间:2024/05/22 23:51

错误案例

现象描述:某天发布后,发现旺铺不能访问了;最后经过开发工程师和架构师一起的跟踪发现,原因是从cache取出来的member对象对应的旺铺标志没有了。

是否拥有旺铺的标志是存放到member表multi_sign的一个字段中


错误分析

现在我们使用cache的地方有很多了,一般放入cache的value都是经过序列化的对象,万一哪天有个需求,需要修改一下这个对象,增加一个属性,而你忘记更新serialVersionUID,灾难来临了。

public class MyClass implements Serializable {    private static final long serialVersionUID = -6849794470754667710L;    private String memberId;    ……}

经过需求增加了一个属性flag

public class MyClass implements Serializable {    //增加属性后    private static final long serialVersionUID = -6849794470754667710L;private String memberId;private Boolean flag;//增加了属性    ……}

增加属性后,UID没有变化,导致已有cache的数据还可以反序列化成功,但是flag字段赋值是空的,导致程序异常。 serialVersionUID的原理可以参看:http://wangduowu.javaeye.com/blog/319297


正确用法

正确用法:

public class MyClass implements Serializable {    //生成新的UID,eclipse既有这功能    private static final long serialVersionUID = - 6525971244576446994L;    private String memberId;    private Boolean flag;//新加的属性    ……}

UID重新生成后,反序列化就不成功,这时你的程序会走else的分支,一般是到数据库拿数据,再放入cache.


测试关注点

如果你的需求涉及到cache,一定要测试到cache已有数据的情况下,程序是否做到兼容。


原创粉丝点击