Java序列化與反序列化

ava序列化與反序列化是什麼?爲什麼需要序列化與反序列化?如何實現Java序列化與反序列化?本文圍繞這些問題進行了探討。

 1.Java序列化與反序列化

 Java序列化是指把Java對象轉換爲字節序列的過程;而Java反序列化是指把字節序列恢復爲Java對象的過程。

 2.爲什麼需要序列化與反序列化

 我們知道,當兩個進程進行遠程通信時,可以相互發送各種類型的數據,包括文本、圖片、音頻、視頻等, 而這些數據都會以二進制序列的形式在網絡上傳送。那麼當兩個Java進程進行通信時,能否實現進程間的對象傳送呢?答案是可以的。如何做到呢?這就需要Java序列化與反序列化了。換句話說,一方面,發送方需要把這個Java對象轉換爲字節序列,然後在網絡上傳送;另一方面,接收方需要從字節序列中恢復出Java對象。

 當我們明晰了爲什麼需要Java序列化和反序列化後,我們很自然地會想Java序列化的好處。其好處一是實現了數據的持久化,通過序列化可以把數據永久地保存到硬盤上(通常存放在文件裏),二是,利用序列化實現遠程通信,即在網絡上傳送對象的字節序列。

3.如何實現Java序列化與反序列化

1)JDK類庫中序列化API

 java.io.ObjectOutputStream:表示對象輸出流

它的writeObject(Object obj)方法可以對參數指定的obj對象進行序列化,把得到的字節序列寫到一個目標輸出流中。

java.io.ObjectInputStream:表示對象輸入流

它的readObject()方法源輸入流中讀取字節序列,再把它們反序列化成爲一個對象,並將其返回。

2)實現序列化的要求

只有實現了Serializable或Externalizable接口的類的對象才能被序列化,否則拋出異常。

3)實現Java對象序列化與反序列化的方法

假定一個Student類,它的對象需要序列化,可以有如下三種方法:

方法一:若Student類僅僅實現了Serializable接口,則可以按照以下方式進行序列化和反序列化

ObjectOutputStream採用默認的序列化方式,對Student對象的非transient的實例變量進行序列化。

ObjcetInputStream採用默認的反序列化方式,對對Student對象的非transient的實例變量進行反序列化。

方法二:若Student類僅僅實現了Serializable接口,並且還定義了readObject(ObjectInputStream in)和writeObject(ObjectOutputSteam out),則採用以下方式進行序列化與反序列化。

ObjectOutputStream調用Student對象的writeObject(ObjectOutputStream out)的方法進行序列化。

ObjectInputStream會調用Student對象的readObject(ObjectInputStream in)的方法進行反序列化。

方法三:若Student類實現了Externalnalizable接口,且Student類必須實現readExternal(ObjectInput in)和writeExternal(ObjectOutput out)方法,則按照以下方式進行序列化與反序列化。

ObjectOutputStream調用Student對象的writeExternal(ObjectOutput out))的方法進行序列化。

ObjectInputStream會調用Student對象的readExternal(ObjectInput in)的方法進行反序列化。

4)JDK類庫中序列化的步驟

步驟一:創建一個對象輸出流,它可以包裝一個其它類型的目標輸出流,如文件輸出流:

ObjectOutputStream out = new ObjectOutputStream(new fileOutputStream(“D:\\objectfile.obj”));

步驟二:通過對象輸出流的writeObject()方法寫對象:

out.writeObject(“Hello”);

out.writeObject(new Date());

5)JDK類庫中反序列化的步驟

步驟一:創建一個對象輸入流,它可以包裝一個其它類型輸入流,如文件輸入流:

ObjectInputStream in = new ObjectInputStream(new fileInputStream(“D:\\objectfile.obj”));

步驟二:通過對象輸出流的readObject()方法讀取對象:

String obj1 = (String)in.readObject();

Date obj2 = (Date)in.readObject();

說明:爲了正確讀取數據,完成反序列化,必須保證向對象輸出流寫對象的順序與從對象輸入流中讀對象的順序一致。

爲了更好地理解Java序列化與反序列化,選擇方法一編碼實現。


轉載自:http://blog.csdn.net/wangloveall/article/details/7992448/

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