Java序列化與反序列化是什么?
Java序列化是指把Java對象轉換為字節序列的過程,而Java反序列化是指把字節序列恢復為Java對象的過程:
-
序列化:對象序列化的最主要的用處就是在傳遞和保存對象的時候,保證對象的完整性和可傳遞性。序列化是把對象轉換成有序字節流,以便在網絡上傳輸或者保存在本地文件中。核心作用是對象狀態的保存與重建。
-
反序列化:客戶端從文件中或網絡上獲得序列化后的對象字節流,根據字節流中所保存的對象狀態及描述信息,通過反序列化重建對象。
為什么需要序列化與反序列化?
為什么要序列化,那就是說一下序列化的好處嘍,序列化有什么什么優點,所以我們要序列化。
一:對象序列化可以實現分布式對象。
主要應用例如:RMI(即遠程調用Remote Method Invocation)要利用對象序列化運行遠程主機上的服務,就像在本地機上運行對象時一樣。
二:java對象序列化不僅保留一個對象的數據,而且遞歸保存對象引用的每個對象的數據。
可以將整個對象層次寫入字節流中,可以保存在文件中或在網絡連接上傳遞。利用對象序列化可以進行對象的"深復制",即復制對象本身及引用的對象本身。序列化一個對象可能得到整個對象序列。
三:序列化可以將內存中的類寫入文件或數據庫中。
比如:將某個類序列化后存為文件,下次讀取時只需將文件中的數據反序列化就可以將原先的類還原到內存中。也可以將類序列化為流數據進行傳輸。
總的來說就是將一個已經實例化的類轉成文件存儲,下次需要實例化的時候只要反序列化即可將類實例化到內存中並保留序列化時類中的所有變量和狀態。
四:對象、文件、數據,有許多不同的格式,很難統一傳輸和保存。
序列化以后就都是字節流了,無論原來是什么東西,都能變成一樣的東西,就可以進行通用的格式傳輸或保存,傳輸結束以后,要再次使用,就進行反序列化還原,這樣對象還是對象,文件還是文件。
如何實現Java序列化與反序列化
首先我們要把准備要序列化類,實現 Serializabel接口
例如:我們要Person類里的name和age都序列化
import java.io.Serializable; public class Person implements Serializable { //本類可以序列化 private String name; private int age; public Person(String name, int age) { this.name = name; this.age = age; } public String toString() { return "姓名:" + this.name + ",年齡" + this.age; } }
然后:我們將name和age序列化(也就是把這2個對象轉為二進制,理解為“打碎”)
package org.lxh.SerDemo; import java.io.File; import java.io.FileOutputStream; import java.io.ObjectOutputStream; public class ObjectOutputStreamDemo { //序列化 public static void main(String[] args) throws Exception { //序列化后生成指定文件路徑 File file = new File("D:" + File.separator + "person.ser"); ObjectOutputStream oos = null; //裝飾流(流) oos = new ObjectOutputStream(new FileOutputStream(file)); //實例化類 Person per = new Person("張三", 30); oos.writeObject(per); //把類對象序列化 oos.close(); } }
一個很簡單的示例,文章以應答面試提問為主,更深了解序列化與反序列化,需要你上網多參考資料。
比如:
《Java對象的序列化(Serialization)和反序列化詳解》
https://blog.csdn.net/yaomingyang/article/details/79321939
《Java 序列化的高級認識》
https://www.ibm.com/developerworks/cn/java/j-lo-serial/
好了,學起來!
最近三期