对readResolve的一点认识
2012-02-06 21:59
302 查看
最近看effecitve java 2中有一段关于readResolve的使用,经过上网查阅资料得到以下总结:
我们知道java 对象的序列化操作是实现Serializable接口,我们就可以把它往内存地写再从内存里读出而"组装"成一个跟原来一模一样的对象. 但是当我们遇到单例序列化的时候,就出现问题了。当从内存读出而组装的对象破坏了单例的规则,会创建新的对象。单例要求JVM只有一个对象,而通过反序化时就会产生一个克隆的对象,这就打破了单例的规则。
当把 Elvis 对象(通过getInstance方法获得的那个单例对象)序列化后再从内存中读出时, 就有一个全新但跟原来一样的Elvis 对象存在了. 那怎么来维护单例模式呢?这就要用到readResolve方法了. 如下所示:
这样当JVM从内存中反序列化地"组装"一个新对象时,就会自动调用这个 readResolve方法来返回我们指定好的对象了, 单例规则也就得到了保证.
我们知道java 对象的序列化操作是实现Serializable接口,我们就可以把它往内存地写再从内存里读出而"组装"成一个跟原来一模一样的对象. 但是当我们遇到单例序列化的时候,就出现问题了。当从内存读出而组装的对象破坏了单例的规则,会创建新的对象。单例要求JVM只有一个对象,而通过反序化时就会产生一个克隆的对象,这就打破了单例的规则。
public class Elvis implements Serializable{ /** * */ private static final long serialVersionUID = 1L; private static Elvis elv = new Elvis(); private Elvis(){ } public static Elvis getInstance(){ return elv; } }
当把 Elvis 对象(通过getInstance方法获得的那个单例对象)序列化后再从内存中读出时, 就有一个全新但跟原来一样的Elvis 对象存在了. 那怎么来维护单例模式呢?这就要用到readResolve方法了. 如下所示:
public class Elvis implements Serializable{ /** * */ private static final long serialVersionUID = 1L; private static Elvis elv = new Elvis(); private Elvis(){ } public static Elvis getInstance(){ return elv; } //readResolve method to preserve singleton property private Object readResolve(){ /** * Return the one ture Elvis and let the garbage collector * take care of the Elvis impersonator */ return elv; } }
这样当JVM从内存中反序列化地"组装"一个新对象时,就会自动调用这个 readResolve方法来返回我们指定好的对象了, 单例规则也就得到了保证.
相关文章推荐
- 谈谈我对资本主义和社会主义的一点认识
- 三层--对你的认识再多一点
- 关于函数调用和尾递归的一点认识
- OLE Automation一点粗浅认识
- 关于对设计模式的一点认识
- 黑马程序员-————学完String后的一点认识。
- Linux中configure命令的一点认识
- 每天学一点Flash(54) 认识面向对象的三大特性
- 关于C#的索引一点认识
- SLAM的一点认识
- HttpRequest的QueryString属性 的一点认识
- 视觉SLAM研究分析的一点认识
- 今天对于自定义事件与方法的区别有了一点感性的认识
- canvas.translate(x,y)一点新的认识
- 有了一点新认识
- 对虚拟函数动态绑定的一点认识
- C语言学习过程中对于strcat函数使用的一点认识
- 对于图像处理库的一点认识
- 对堆栈的一点认识
- Dubbo和Zookeeper的一点认识