java 中序列化與readResolve()方法的實(shí)例詳解
readResolve方法是作用是什么?這個(gè)方法跟對(duì)象的序列化相關(guān)(這樣倒是解釋了為什么 readResolve方法是private修飾的)。 怎么跟對(duì)象的序列化相關(guān)了?
下面我們先簡(jiǎn)要地回顧下對(duì)象的序列化。一般來(lái)說(shuō),一個(gè)類(lèi)實(shí)現(xiàn)了 Serializable接口,我們就可以把它往內(nèi)存地寫(xiě)再?gòu)膬?nèi)存里讀出而"組裝"成一個(gè)跟原來(lái)一模一樣的對(duì)象。不過(guò)當(dāng)序列化遇到單例時(shí),里邊就有了個(gè)問(wèn)題:從內(nèi)存讀出而組裝的對(duì)象破壞了單例的規(guī)則。單例是要求一個(gè)JVM中只有一個(gè)類(lèi)對(duì)象的,而現(xiàn)在通過(guò)反序列,一個(gè)新的對(duì)象克隆了出來(lái)。如下例所示:
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; } } |
當(dāng)把 MySingleton對(duì)象(通過(guò)getInstance方法獲得的那個(gè)單例對(duì)象)序列化后再?gòu)膬?nèi)存中讀出時(shí),就有一個(gè)全新但跟原來(lái)一樣的MySingleton對(duì)象存在了。那怎么來(lái)維護(hù)單例模式呢?這就要用到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; } } |
這樣,當(dāng)JVM從內(nèi)存中反序列化地"組裝"一個(gè)新對(duì)象時(shí),就會(huì)自動(dòng)調(diào)用這個(gè) readResolve方法來(lái)返回我們指定好的對(duì)象了,單例規(guī)則也就得到了保證。
以上就是java 中序列化與readResolve()方法的實(shí)例,如有疑問(wèn)請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
原文鏈接:http://blog.csdn.net/zmx729618/article/details/52814472