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

错误案例

现象描述:某天发布后,发现旺铺不能访问了;最后经过开发工程师和架构师一起的跟踪发现,原因是从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已有数据的情况下,程序是否做到兼容。


你可能感兴趣的:(alibaba,java,cache,string,class,eclipse,测试,数据库)