java 中序列化與readResolve()方法的實例詳解
readResolve方法是作用是什么?這個方法跟對象的序列化相關(這樣倒是解釋了為什么 readResolve方法是private修飾的)。 怎么跟對象的序列化相關了?
下面我們先簡要地回顧下對象的序列化。一般來說,一個類實現了 Serializable接口,我們就可以把它往內存地寫再從內存里讀出而"組裝"成一個跟原來一模一樣的對象。不過當序列化遇到單例時,里邊就有了個問題:從內存讀出而組裝的對象破壞了單例的規則。單例是要求一個JVM中只有一個類對象的,而現在通過反序列,一個新的對象克隆了出來。如下例所示:
Java代碼:
1
2
3
4
5
|
public final class MySingleton implements Serializable { private MySingleton() { } private static final MySingleton INSTANCE = new MySingleton(); public static MySingleton getInstance() { return INSTANCE; } } |
當把 MySingleton對象(通過getInstance方法獲得的那個單例對象)序列化后再從內存中讀出時,就有一個全新但跟原來一樣的MySingleton對象存在了。那怎么來維護單例模式呢?這就要用到readResolve方法。 如下所示:
1
2
3
4
5
6
7
8
9
10
|
public final class MySingleton implements Serializable{ private MySingleton() { } private static final MySingleton INSTANCE = new MySingleton(); public static MySingleton getInstance() { return INSTANCE; } private Object readResolve() throws ObjectStreamException { // instead of the object we're on, // return the class variable INSTANCE return INSTANCE; } } |
這樣,當JVM從內存中反序列化地"組裝"一個新對象時,就會自動調用這個 readResolve方法來返回我們指定好的對象了,單例規則也就得到了保證。
以上就是java 中序列化與readResolve()方法的實例,如有疑問請留言或者到本站社區交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
原文鏈接:http://blog.csdn.net/zmx729618/article/details/52814472