Java序列化是一種將對象的狀態信息轉換為字節流,以便在網絡上傳輸或將其保存到本地文件系統的過程。序列化后的對象可以在稍后的時間點被反序列化,即將字節流恢復為原始對象。
序列化的主要目的是為了在不同的Java虛擬機(JVM)之間傳輸對象,或者在持久化存儲中保存對象的狀態。這樣,當需要重新創建對象時,可以從存儲的字節流中反序列化對象。
在Java中,要實現序列化,需要讓類實現java.io.Serializable
接口。這個接口沒有任何方法,只是一個標記接口,表示該類的對象可以被序列化。
序列化和反序列化的過程通常使用java.io.ObjectOutputStream
和java.io.ObjectInputStream
類來完成。下面是一個簡單的序列化和反序列化示例:
import java.io.*;
class Person implements Serializable {
private String name;
private int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
// getter and setter methods
}
public class SerializeDemo {
public static void main(String[] args) {
// 創建一個Person對象
Person person = new Person("John Doe", 30);
try {
// 序列化Person對象到文件
FileOutputStream fileOut = new FileOutputStream("person.ser");
ObjectOutputStream out = new ObjectOutputStream(fileOut);
out.writeObject(person);
out.close();
fileOut.close();
System.out.println("Serialized Person object is saved in person.ser");
} catch (IOException e) {
e.printStackTrace();
}
try {
// 從文件反序列化Person對象
FileInputStream fileIn = new FileInputStream("person.ser");
ObjectInputStream in = new ObjectInputStream(fileIn);
Person restoredPerson = (Person) in.readObject();
in.close();
fileIn.close();
System.out.println("Restored Person object: " + restoredPerson.getName() + ", " + restoredPerson.getAge());
} catch (IOException | ClassNotFoundException e) {
e.printStackTrace();
}
}
}
在這個示例中,我們創建了一個Person
類,該類實現了Serializable
接口。然后,我們創建了一個Person
對象,并將其序列化到名為"person.ser"的文件中。接下來,我們從該文件中反序列化Person
對象,并打印其屬性。