Java串行化(Serialization序列化)技術可使你將一個對象的狀態寫入一個Byte流裏,而且能夠從其餘地方把該Byte流裏的數據讀出來,從新構造一個相同的對象。這種機制容許你將對象經過網絡進行傳播,並能夠隨時把對象持久化到數據庫、文件等系統裏。Java串行化機制是RMI、EJB等技術的基礎,用途是利用對象的串行化實現保存應用程序的當前狀態,下次再啓動的時候將自動恢復到上次執行的狀態。 java
序列化就是一種用來處理對象流的機制,所謂對象流也就是將對象的內容進行流化。能夠對流化後的對象進行讀寫操做,也可將流化後的對象傳輸於網絡之間。序列化是爲了解決在對對象流進行讀寫操做時引起的問題。 數據庫
序列化的實現:將須要被序列化的類實現Serializable接口,而後使用一個輸出流(FileOutputStream)來構造一個ObjectOutputStream(對象流)對象,接着,使用ObjectOutputStream對象的wirteObject(Object obj)方法就能夠將參數爲obj的對象寫出(即保存其狀態),要回復的話則用輸入流。 網絡
串行化特色: 函數
(1)若是某個類可以被串行化,其子類也能夠被串行化。若是該父類已經實現了可串行化接口,則其父類的相應字段及屬性的處理和該類相同;若是該類的父類沒有實現可串行化接口,則該類的父類全部字段屬性不會串行化。 this
(2)聲明爲static和transient類型的成員數據不能被串行化。由於static表明類的狀態,transient表明對象的臨時數據; spa
(3)相關的類和接口:在java.io包中提供的涉及對象的串行化的類和接口有:ObjectOutput接口、ObjectOutputStream類、ObjectInput接口、ObjectInputStream類。 設計
1)ObjectOutput接口:它繼承DataOutput接口並支持對象的串行化,其內的writeObject()方法實現存儲一個對象。ObjectIutput接口:繼承DataInput接口並支持對象的串行化,其內的readObject()方法實現讀取一個對象。 code
2)ObjectOutputStream類:繼承OutputStream類而且實現ObjectOutput接口。利用該類來實現將對象存儲(調用ObjectOutput接口中wirteObject()方法)。 對象
ObjectInputStream類:繼承InputStream類而且實現ObjectInput接口。利用該類實現讀取一個對象(調用ObjectIutput接口中readObject())。 繼承
對於父類的處理,若是父類沒有實現串行化接口,則其必須有默認的構造函數。不然編譯的時候就會報錯。可是若把父類標記爲能夠串行化,則在反串行化的時候,其默認構造函數不會被調用。由於java對串行化的對象進行反串行化的時候,直接從流裏獲取其對象數據來生成一個對象實例,而不是經過構造函數來完成。
public interface Serializable類經過實現 java.io.Serializable 接口以啓用其序列化功能。未實現此接口的類將沒法使其任何狀態序列化或反序列化。
所謂的Serializable,就是java提供的通用數據保存和讀取的接口。至於從什麼地方讀出來和保存到哪裏去都被隱藏在函數參數的背後了。這樣子,任何類型只要實現了Serializable接口,就能夠被保存到文件中,或者做爲數據流經過網絡發送到別的地方。也能夠用管道來傳輸到系統的其餘程序中。這樣子極大的簡化了類的設計。只要設計一個保存一個讀取功能就能解決上面說得全部問題。
一、序列化是幹什麼的?
簡單說就是爲了保存在內存中的各類對象的狀態(實例變量),而且能夠把保存的對象狀態再讀出來。雖然你用本身各類各樣的方法來保存object states,但Java給你提供一種應該比你本身好的保存對象狀態的機制,就是序列化。
二、什麼狀況下須要序列化
a)當你想把內存中的對象狀態保存到一個文件中或者數據庫中;
b)當你想用套接字在網絡上傳送對象
c)當你想經過RMI傳輸對象的時候;
三、當對一個對象實現序列化時,究竟發生了什麼?
在沒有序列化前,每一個保存在堆(Heap)中的對象都有相應的狀態(statge),即實例變量(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);
四、實現序列化(保存到一個文件)的步驟
1)Make a FileOutputStream //建立個Fileoutputsteam
FileOutputStream fs = new FileOutputStream("foo.ser");
2)Make a ObjectOutputStream //建立個objiectoutputstream
ObjectOutputStream os = new ObjectOutputStream(fs);
3)write the object //寫入特定類的對象, 用方法writeobjiect()
os.writeObject(myObject1);
os.writeObject(myObject2);
os.writeObject(myObject3);
4) close the ObjectOutputStream //關閉流。
os.close();
五、舉例說明
java 代碼 import java.io.*; public class Box implements Serializable //要保存的對象類必須實現序列化接口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(); } } }反序列化方法
Public static void seserialize(string filename) throws Exception { // 反序列化(讀出保存的對象文件) ObjectInputStream in = new ObjectInputStream (new FileInputStream(filename)); Box box = (Box) (in.readbject()); System.out.println(box.toString()); In.Closer(); }