Java Serializable(序列化)的理解

來源:互聯網
上載者:User
  

1、序列化是幹什麼的?
   
  
簡單說就是為了儲存在記憶體中的各種對象的狀態(也就是執行個體變數,不是方法),並且可以把儲存的對象狀態再讀出來。雖然你可以用你自己的各種各樣的方法來儲存object
states,但是Java給你提供一種應該比你自己好的儲存對象狀態的機制,那就是序列化。

2、什麼情況下需要序列化  
   
a)當你想把的記憶體中的對象狀態儲存到一個檔案中或者資料庫中時候;
   
b)當你想用通訊端在網路上傳送對象的時候;
   
c)當你想通過RMI傳輸對象的時候;

3、當對一個對象實現序列化時,究竟發生了什嗎?
   
在沒有序列化前,每個儲存在堆(Heap)中的對象都有相應的狀態(state),即執行個體變數(instance
ariable)比如:
   

java 代碼
  1.  Foo  myFoo = new Foo();  
  2.  myFoo .setWidth(37);  
  3.  myFoo.setHeight(70);

      
當通過下面的代碼序列化之後,MyFoo對象中的width和Height執行個體變數的值(37,70)都被儲存到foo.ser檔案中,這樣以後又可以把它從檔案中讀出來,重新在堆中建立原來的對象。當然儲存時候不僅僅是儲存對象的執行個體變數的值,JVM還要儲存一些小量資訊,比如類的類型等以便恢複原來的對象。java 代碼

  1. FileOutputStream fs = new FileOutputStream("foo.ser");  
  2. ObjectOutputStream os = new ObjectOutputStream(fs);  
  3. os.writeObject(myFoo);  

4、實現序列化(儲存到一個檔案)的步驟
 
a)Make a
FileOutputStream   
     java 代碼
     FileOutputStream fs = new FileOutputStream("foo.ser");      
   

  b)Make a
ObjectOutputStream   
  
         java 代碼


     ObjectOutputStream os =  new ObjectOutputStream(fs); 

      c)write the object     java 代碼
         os.writeObject(myObject1);  

         os.writeObject(myObject2);  

         os.writeObject(myObject3);  

        d) close the
      ObjectOutputStream     java 代碼


           os.close(); 

        5、舉例說明

        java
        代碼
          1.  import java.io.*;
          2.    
          3.  public class  Box implements Serializable  
          4.  {  
          5.      private int width;  
          6.      private int height;  
          7.    
          8.      public void setWidth(int width){  
          9.          this.width  = width;  
          10.      }  
          11.      public void setHeight(int height){  
          12.          this.height = height;  
          13.      }  
          14.    
          15.      public static void main(String[] args){  
          16.          Box myBox = new Box();  
          17.          myBox.setWidth(50);  
          18.          myBox.setHeight(30);  
          19.    
          20.          try{  
          21.              FileOutputStream fs = new FileOutputStream("foo.ser");  
          22.              ObjectOutputStream os =  new ObjectOutputStream(fs);  
          23.              os.writeObject(myBox);  
          24.              os.close();  
          25.          }catch(Exception ex){  
          26.              ex.printStackTrace();  
          27.          }  
          28.      }  
          29.  } 

          6、相關注意事項
             
          a)序列化時,只對對象的狀態進行儲存,而不管對象的方法;
              b)當一個父類實現序列化,子類自動實現序列化,不需要顯式實現Serializable介面;
             
          c)當一個對象的執行個體變數引用其他對象,序列化該對象時也把引用對象進行序列化;
             
          d)並非所有的對象都可以序列化,,至於為什麼不可以,有很多原因了,比如:
             
             
          1.安全方面的原因,比如一個對象擁有private,public等field,對於一個要傳輸的對象,比如寫到檔案,或者進行rmi傳輸 
          等等,在序列化進行傳輸的過程中,這個對象的private等域是不受保護的。
                
          2.
          資源分派方面的原因,比如socket,thread類,如果可以序列化,進行傳輸或者儲存,也無法對他們進行重新的資源分 
          配,而且,也是沒有必要這樣實現。

          聯繫我們

          該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

          如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

          A Free Trial That Lets You Build Big!

          Start building with 50+ products and up to 12 months usage for Elastic Compute Service

          • Sales Support

            1 on 1 presale consultation

          • After-Sales Support

            24/7 Technical Support 6 Free Tickets per Quarter Faster Response

          • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.