Java 序列化和反序列化機(jī)制是 Java 語言自帶的一種機(jī)制,用于實(shí)現(xiàn)對象的數(shù)據(jù)持久化。在 Java 程序中,任何可以被存儲到文件或者傳輸?shù)骄W(wǎng)絡(luò)上的對象,都可以被序列化。Java 序列化指的是將 Java 對象轉(zhuǎn)換為字節(jié)序列的過程,而反序列化則是將字節(jié)序列轉(zhuǎn)換成 Java 對象的過程。
Java 序列化機(jī)制可以用來實(shí)現(xiàn)數(shù)據(jù)的長期保存,也可以用來將數(shù)據(jù)通過網(wǎng)絡(luò)進(jìn)行傳輸。例如,在分布式系統(tǒng)中,可以將對象序列化之后,通過網(wǎng)絡(luò)傳輸?shù)狡渌麢C(jī)器上,從而實(shí)現(xiàn)分布式計(jì)算。
Java 序列化和反序列化的機(jī)制都是通過 Java 的 ObjectOutputStream 和 ObjectInputStream 來實(shí)現(xiàn)的。ObjectOutputStream 將對象序列化為字節(jié)流,并將其發(fā)送到輸出流中。ObjectInputStream 從輸入流中讀取字節(jié)序列,并反序列化為對象。
// Java 序列化示例代碼 public class SerializationExample { public static void main(String[] args) throws Exception { // 創(chuàng)建一個(gè) User 對象 User user = new User("張三", 25); // 創(chuàng)建一個(gè)輸出流 FileOutputStream fos = new FileOutputStream("user.ser"); // 創(chuàng)建一個(gè)對象輸出流 ObjectOutputStream oos = new ObjectOutputStream(fos); // 將 User 對象寫入到對象輸出流中 oos.writeObject(user); // 關(guān)閉對象輸出流和輸出流 oos.close(); fos.close(); } }
// Java 反序列化示例代碼 public class DeserializationExample { public static void main(String[] args) throws Exception { // 創(chuàng)建一個(gè)輸入流 FileInputStream fis = new FileInputStream("user.ser"); // 創(chuàng)建一個(gè)對象輸入流 ObjectInputStream ois = new ObjectInputStream(fis); // 從對象輸入流中讀取 User 對象 User user = (User) ois.readObject(); // 打印 User 對象 System.out.println(user); // 關(guān)閉對象輸入流和輸入流 ois.close(); fis.close(); } }
需要注意的是,序列化和反序列化需要保證類的定義是相同的。如果類的定義發(fā)生變化,可能會導(dǎo)致反序列化失敗。因此,為了保證程序的可靠性,通常建議在序列化和反序列化時(shí)使用版本號。