程序員自學之旅(四)序列化

1、序列化是幹什麼的?

 
 簡單說就是爲了保存在內存中的各種對象的狀態,並且可以把保存的對象狀態再讀出來。雖然你可以用你自己的各種各樣的方法來保存Object States,但是Java給你提供一種應該比你自己好的保存對象狀態的機制,那就是序列化。


2、什麼情況下需要序列化


a)當你想把的內存中的對象保存到一個文件中或者數據庫中時候;

b)當你想用套接字在網絡上傳送對象的時候;

c)當你想通過RMI傳輸對象的時候;


3、當對一個對象實現序列化時,究竟發生了什麼?


在沒有序列化前,每個保存在堆(Heap)中的對象都有相應的狀態(state),即實例變量(instance ariable)比如:


Foo myFoo = new Foo();

myFoo .setWidth(37);

myFoo.setHeight(70);

 
當通過下面的代碼序列化之後,MyFoo對象中的width和Height實例變量的值(37,70)都被保存到foo.ser文件中,這樣以後又可以把它 從文件中讀出來,重新在堆中創建原來的對象。當然保存時候不僅僅是保存對象的實例變量的值,JVM還要保存一些小量信息,比如類的類型等以便恢復原來的對 象。


FileOutputStream fs = new FileOutputStream("foo.ser");

ObjectOutputStream os = new ObjectOutputStream(fs); 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 代碼

import java.io.*;
 


public class Box implements Serializable
{
        
private int width;
        
private int height;
        

public void setWidth(int width){
             this.width = width;
}
        
public void setHeight(int height){             
            this.height = height;
}
        

public static void main(String[] args){
             Box myBox = new Box();
 
            myBox.setWidth(50);
            
myBox.setHeight(30);
            

try{
                
FileOutputStream fs = new FileOutputStream("foo.ser");
                
ObjectOutputStream os = new ObjectOutputStream(fs);
 
                os.writeObject(myBox);
                 os.close();
}
            catch(Exception ex){
                    
ex.printStackTrace();
}
}

}


6、相關注意事項
a)當一個父類實現序列化,子類自動實現序列化,不需要顯式實現Serializable接口;

b)當一個對象的實例變量引用其他對象,序列化該對象時也把引用對象進行序列化;

c)並非所有的對象都可以序列化,,至於爲什麼不可以,有很多原因了,比如:

 
1.安全方面的原因,比如一個對象擁有private,public等field,對於一個要傳輸的對象,比如寫到文件,或者進行rmi傳輸 等等,在序列化進行傳輸的過程中,這個對象的private等域是不受保護的。
 
2. 資源分配方面的原因,比如socket,thread類,如果可以序列化,進行傳輸或者保存,也無法對他們進行重新的資源分 配,而且,也是沒有必要這樣實現。
不好意思,網上的資料。可以看看


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章