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

24 篇文章 0 订阅

错误案例

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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值