使用transient关键字解决ehcache序列化错误

使用Ehcache时发现个不起眼的小问题

在一个Model中有以下代码:

public class MyModel implements Serializable {

    private static final long serialVersionUID = -990334519496260591L;

    private IUserService us = ServiceManager.me.getUserService();

    //getter and setter

}

在将这个Model的一个实例缓存到Ehcache时,如果恰好Ehcache配置了允许保存到磁盘,那么就会提示错误:

ERROR DiskStorageFactory   Disk Write of xxxxxxx failed:
java.io.NotSerializableException: com.my.service.impl.UserServiceImpl$$EnhancerByGuice$$80ede2b6

看错误提示,很明显是 UserServiceImpl 对象无法序列化,原来是Ehcache把这个服务逻辑也看成了Model的普通属性

正常情况下,将 UserServiceImpl 实现 Serializable 接口就可以解决问题

但实际上,这个服务是无状态的单列模式,将它序列化到磁盘是没有任何意义的,还会增加磁盘的IO开销

那怎么样才能将Model成功缓存,又能刨除这些服务逻辑的属性呢?

 

这时候,一个不起眼的关键字发挥了作用:transient

将上面的代码改成如下,其实只是增加了这个关键字而已:

public class MyModel implements Serializable {

    private static final long serialVersionUID = -990334519496260591L;

    private transient IUserService us = ServiceManager.me.getUserService();

    //getter and setter

}

再次缓存时,将不会提示错误。

这里有一篇文章对 transient 关键字进行了更详细的阐述:https://www.cnblogs.com/lanxuezaipiao/p/3369962.html

posted @ 2018-07-13 16:31  网无忌  阅读(577)  评论(0编辑  收藏  举报