亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java 中序列化與readResolve()方法的實例詳解

 更新時間:2017年08月07日 14:18:29   作者:零度anngle  
這篇文章主要介紹了java 中序列化與readResolve()方法的實例詳解的相關資料,這里提供實例幫助大家理解這部分知識,需要的朋友可以參考下

java 中序列化與readResolve()方法的實例詳解

    readResolve方法是作用是什么?這個方法跟對象的序列化相關(這樣倒是解釋了為什么 readResolve方法是private修飾的)。 怎么跟對象的序列化相關了?

       下面我們先簡要地回顧下對象的序列化。一般來說,一個類實現(xiàn)了 Serializable接口,我們就可以把它往內存地寫再從內存里讀出而"組裝"成一個跟原來一模一樣的對象。不過當序列化遇到單例時,里邊就有了個問題:從內存讀出而組裝的對象破壞了單例的規(guī)則。單例是要求一個JVM中只有一個類對象的,而現(xiàn)在通過反序列,一個新的對象克隆了出來。如下例所示:

  Java代碼:

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方法。 如下所示: 

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方法來返回我們指定好的對象了,單例規(guī)則也就得到了保證。

以上就是java 中序列化與readResolve()方法的實例,如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關文章

最新評論