標籤:cep add null 反序 執行個體化 資料流 serial 有關 就是
Java 序列化
Java 提供了一種對象序列化的機制,該機制中,一個對象可以被表示為一個位元組序列,該位元組序列包括該對象的資料、有關對象的類型的資訊和儲存在對象中資料的類型。
將序列化對象寫入檔案之後,可以從檔案中讀取出來,並且對它進行還原序列化,也就是說,對象的類型資訊、對象的資料,還有對象中的資料類型可以用來在記憶體中建立對象。
整個過程都是Java虛擬機器(JVM)獨立的,也就是說,在一個平台上序列化的對象可以在另一個完全不同的平台上還原序列化該對象。
類ObjectInputStream 和ObjectOutputStream是高層次的資料流,它們包含序列化和還原序列化對象的方法。
ObjectOutputStream 類包含很多寫方法來寫各種資料類型,但是一個特別的方法例外:
public final void writeObject(Object x) throws IOException
上面的方法序列化一個對象,並將它發送到輸出資料流。相似的ObjectInputStream 類包含如下還原序列化一個對象的方法:
public final Object readObject() throws IOException, ClassNotFoundException
該方法從流中取出下一個對象,並將對象還原序列化。它的傳回值為Object,因此,你需要將它轉換成合適的資料類型。
為了示範序列化在Java中是怎樣工作的,我將使用之前教程中提到的Employee類,假設我們定義了如下的Employee類,該類實現了Serializable 介面。
public class Employee implements java.io.Serializable{ public String name; public String address; public transient int SSN; public int number; public void mailCheck() { System.out.println("Mailing a check to " + name + " " + address); }}
請注意,一個類的對象要想序列化成功,必須滿足兩個條件:
該類必須實現 java.io.Serializable 對象。
該類的所有屬性必須是可序列化的。如果有一個屬性不是可序列化的,則該屬性必須註明是短暫的。
如果你想知道一個Java標準類是否是可序列化的,請查看該類的文檔。檢驗一個類的執行個體是否能序列化十分簡單, 只需要查看該類有沒有實現java.io.Serializable介面。
序列化對象
ObjectOutputStream 類用來序列化一個對象,如下的SerializeDemo例子執行個體化了一個Employee對象,並將該對象序列化到一個檔案中。
該程式執行後,就建立了一個名為employee.ser檔案。該程式沒有任何輸出,但是你可以通過代碼研讀來理解程式的作用。
注意: 當序列化一個對象到檔案時, 按照Java的標準約定是給檔案一個.ser副檔名。
import java.io.*;public class SerializeDemo{ public static void main(String [] args) { Employee e = new Employee(); e.name = "Reyan Ali"; e.address = "Phokka Kuan, Ambehta Peer"; e.SSN = 11122333; e.number = 101; try { FileOutputStream fileOut = new FileOutputStream("/tmp/employee.ser"); ObjectOutputStream out = new ObjectOutputStream(fileOut); out.writeObject(e); out.close(); fileOut.close(); System.out.printf("Serialized data is saved in /tmp/employee.ser"); }catch(IOException i) { i.printStackTrace(); } }}還原序列化對象
下面的DeserializeDemo程式執行個體了還原序列化,/tmp/employee.ser儲存了Employee對象。
import java.io.*;public class DeserializeDemo{ public static void main(String [] args) { Employee e = null; try { FileInputStream fileIn = new FileInputStream("/tmp/employee.ser"); ObjectInputStream in = new ObjectInputStream(fileIn); e = (Employee) in.readObject(); in.close(); fileIn.close(); }catch(IOException i) { i.printStackTrace(); return; }catch(ClassNotFoundException c) { System.out.println("Employee class not found"); c.printStackTrace(); return; } System.out.println("Deserialized Employee..."); System.out.println("Name: " + e.name); System.out.println("Address: " + e.address); System.out.println("SSN: " + e.SSN); System.out.println("Number: " + e.number); }}
以上程式編譯運行結果如下所示:
Deserialized Employee...Name: Reyan AliAddress:Phokka Kuan, Ambehta PeerSSN: 0Number:101
這裡要注意以下要點:
readObject() 方法中的try/catch代碼塊嘗試捕獲 ClassNotFoundException異常。對於JVM可以還原序列化對象,它必須是能夠找到位元組碼的類。如果JVM在還原序列化對象的過程中找不到該類,則拋出一個 ClassNotFoundException異常。
注意,readObject()方法的傳回值被轉化成Employee引用。
當對象被序列化時,屬性SSN的值為111222333,但是因為該屬性是短暫的,該值沒有被發送到輸出資料流。所以還原序列化後Employee對象的SSN屬性為0。
Java--序列化