在 JAVA 中,序列化(Serialization)是指將對象轉(zhuǎn)換為字節(jié)序列的過程,而反序列化(Deserialization)則是指將字節(jié)序列轉(zhuǎn)換回對象的過程。序列化和反序列化主要用于在網(wǎng)絡(luò)傳輸、持久化存儲和進(jìn)程間通信等場景中,將對象以字節(jié)的形式進(jìn)行傳輸或存儲。
序列化的作用和用途如下:
- 網(wǎng)絡(luò)傳輸:在網(wǎng)絡(luò)傳輸中,通常需要將對象轉(zhuǎn)換為字節(jié)流進(jìn)行傳輸。通過序列化,可以將對象轉(zhuǎn)換為字節(jié)流,然后通過網(wǎng)絡(luò)傳輸?shù)搅硪慌_機器上,再通過反序列化將字節(jié)流轉(zhuǎn)換回對象。
- 持久化存儲:在將對象保存到文件或數(shù)據(jù)庫中時,可以使用序列化將對象轉(zhuǎn)換為字節(jié)流,然后將字節(jié)流保存到文件或數(shù)據(jù)庫中。當(dāng)需要讀取對象時,可以通過反序列化將字節(jié)流轉(zhuǎn)換回對象。
- 進(jìn)程間通信:在多進(jìn)程或分布式系統(tǒng)中,不同進(jìn)程或不同機器之間需要進(jìn)行通信。通過序列化,可以將對象轉(zhuǎn)換為字節(jié)流進(jìn)行傳輸,然后通過反序列化將字節(jié)流轉(zhuǎn)換回對象,實現(xiàn)進(jìn)程間或機器間的通信。
Java 提供了內(nèi)置的序列化和反序列化機制,可以通過實現(xiàn) Serializable 接口來實現(xiàn)對象的序列化和反序列化。Serializable 接口是一個標(biāo)記接口,沒有任何方法,只是用來標(biāo)識一個類可以被序列化。
下面是一個示例代碼,演示了如何在 Java 中進(jìn)行對象的序列化和反序列化:
import java.io.*;
public class SerializationDemo {
public static void mAIn(String[] args) {
// 創(chuàng)建一個對象
Person person = new Person("John", 25);
// 將對象序列化到文件中
serializeObject(person, "person.ser");
// 從文件中反序列化對象
Person deserializedPerson = (Person) deserializeObject("person.ser");
// 打印反序列化后的對象
System.out.println(deserializedPerson);
}
// 將對象序列化到文件
private static void serializeObject(Object object, String fileName) {
try (FileOutputStream fileOut = new FileOutputStream(fileName);
ObjectOutputStream objectOut = new ObjectOutputStream(fileOut)) {
objectOut.writeObject(object);
System.out.println("Object serialized successfully.");
} catch (IOException e) {
e.printStackTrace();
}
}
// 從文件中反序列化對象
private static Object deserializeObject(String fileName) {
try (FileInputStream fileIn = new FileInputStream(fileName);
ObjectInputStream objectIn = new ObjectInputStream(fileIn)) {
Object object = objectIn.readObject();
System.out.println("Object deserialized successfully.");
return object;
} catch (IOException | ClassNotFoundException e) {
e.printStackTrace();
return null;
}
}
// 定義一個可序列化的類
private static class Person implements Serializable {
private String name;
private int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public int getAge() {
return age;
}
@Override
public String toString() {
return "Person{" +
"name='" + name + ''' +
", age=" + age +
'}';
}
}
}
在上面的示例代碼中,我們創(chuàng)建了一個可序列化的 Person 類,并實現(xiàn)了 Serializable 接口。然后,我們創(chuàng)建了一個 Person 對象,并將其序列化到文件中。接著,我們從文件中反序列化對象,并打印出反序列化后的對象。
需要注意的是,被序列化的類必須實現(xiàn) Serializable 接口,否則在序列化或反序列化時會拋出 NotSerializableException 異常。另外,被序列化的類的所有屬性也必須是可序列化的,否則同樣會拋出 NotSerializableException 異常。
序列化和反序列化是將對象轉(zhuǎn)換為字節(jié)流和將字節(jié)流轉(zhuǎn)換為對象的過程。在 Java 中,可以通過實現(xiàn) Serializable 接口來實現(xiàn)對象的序列化和反序列化。序列化和反序列化主要用于在網(wǎng)絡(luò)傳輸、持久化存儲和進(jìn)程間通信等場景中,將對象以字節(jié)的形式進(jìn)行傳輸或存儲。通過序列化和反序列化,可以實現(xiàn)對象的傳輸和存儲,方便在不同系統(tǒng)、不同進(jìn)程或不同機器之間進(jìn)行數(shù)據(jù)交換和通信。