Java 串行化技術可使你將一個對象的狀態寫入一個Byte 流裏,而且能夠從其它地方把該Byte 流裏的數據讀出來,從新構造一個相同的對象。這種機制容許你將對象經過網絡進行傳播,並能夠隨時把對象持久化到數據庫、文件等系統裏。Java的串行化機制是RMI、EJB等技術的技術基礎。用途:利用對象的串行化實現保存應用程序的當前工做狀態,下次再啓動的時候將自動地恢復到上次執行的狀態。java
序列化就是一種用來處理對象流的機制,所謂對象流也就是將對象的內容進行流化。能夠對流化後的對象進行讀寫操做,也可將流化後的對象傳輸於網絡之間。序列化是爲了解決在對對象流進行讀寫操做時所引起的問題。數據庫
序列化的實現:將須要被序列化的類實現Serializable接口,而後使用一個輸出流(如:FileOutputStream)來構造一個ObjectOutputStream(對象流)對象,接着,使用ObjectOutputStream對象的writeObject(Object obj)方法就能夠將參數爲obj的對象寫出(即保存其狀態),要恢復的話則用輸入流。安全
二、串行化的特色:網絡
(1)若是某個類可以被串行化,其子類也能夠被串行化。若是該類有父類,則分兩種狀況來考慮,若是該父類已經實現了可串行化接口。則其父類的相應字段及屬性的處理和該類相同;若是該類的父類沒有實現可串行化接口,則該類的父類全部的字段屬性將不會串行化。併發
(2)聲明爲static和transient類型的成員數據不能被串行化。由於static表明類的狀態, transient表明對象的臨時數據;函數
(3)相關的類和接口:在java.io包中提供的涉及對象的串行化的類與接口有ObjectOutput接口、ObjectOutputStream類、ObjectInput接口、ObjectInputStream類。this
(1)ObjectOutput接口:它繼承DataOutput接口而且支持對象的串行化,其內的writeObject()方法實現存儲一個對象。ObjectInput接口:它繼承DataInput接口而且支持對象的串行化,其內的readObject()方法實現讀取一個對象。線程
(2)ObjectOutputStream類:它繼承OutputStream類而且實現ObjectOutput接口。利用該類來實現將對象存儲(調用ObjectOutput接口中的writeObject()方法)。ObjectInputStream類:它繼承InputStream類而且實現ObjectInput接口。利用該類來實現讀取一個對象(調用ObjectInput接口中的readObject()方法)。code
對於父類的處理,若是父類沒有實現串行化接口,則其必須有默認的構造函數(即沒有參數的構造函數)。不然編譯的時候就會報錯。在反串行化的時候,默認構造函數會被調用。可是若把父類標記爲能夠串行化,則在反串行化的時候,其默認構造函數不會被調用。這是爲何呢?這是由於Java 對串行化的對象進行反串行化的時候,直接從流裏獲取其對象數據來生成一個對象實例,而不是經過其構造函數來完成。對象
import java.io.*; public class Cat implements Serializable { private String name; public Cat () { this.name = "new cat"; } public String getName() { return this.name; } public void setName(String name) { this.name = name; } public static void main(String[] args) { Cat cat = new Cat(); try { FileOutputStream fos = new FileOutputStream("catDemo.out"); ObjectOutputStream oos = new ObjectOutputStream(fos); System.out.println(" 1> " + cat.getName()); cat.setName("My Cat"); oos.writeObject(cat); oos.close(); } catch (Exception ex) { ex.printStackTrace(); } try { FileInputStream fis = new FileInputStream("catDemo.out"); ObjectInputStream ois = new ObjectInputStream(fis); cat = (Cat) ois.readObject(); System.out.println(" 2> " + cat.getName()); ois.close(); } catch (Exception ex) { ex.printStackTrace(); } } }//writeObject和readObject自己就是線程安全的,傳輸過程當中是不容許被併發訪問的。因此對象能一個一個接連不斷的傳過來