LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

為什么需要序列化和反序列?為什么不能直接使用對象?

admin
2025年5月3日 18:43 本文熱度 872

工作中,我們經常聽到序列化反序列化,那么,什么是序列化?什么又是反序列化?這篇文章,我們來分析一個招商的面試題:為什么需要序列化反序列化

1. 什么是序列化和反序列化?

簡單來說,序列化就是把一個Java對象轉換成一系列字節的過程,這些字節可以被存儲到文件、數據庫,或者通過網絡傳輸。反過來,反序列化則是把這些字節重新轉換成Java對象的過程。

想象一下,你有一個手機應用中的用戶對象(比如用戶的名字、年齡等信息)。如果你想將這個用戶對象存儲起來,或者發送給服務器,你就需要先序列化它。等到需要使用的時候,再通過反序列化把它恢復成原來的對象。

?

2. 為什么需要序列化?

“為什么需要序列化?為什么不能直接使用對象呢?”這確實是一個好問題,而且很多工作多年的程序員不一定能回答清楚。綜合來看:需要序列化的主要原因有以下三點:

  1. 持久化存儲:當你需要將對象的數據保存到磁盤或數據庫中時,必須把對象轉換成一系列字節。
  2. 網絡傳輸:在分布式系統中,不同的機器需要交換對象數據,序列化是實現這一點的關鍵。
  3. 深拷貝:有時候需要創建對象的副本,序列化和反序列化可以幫助你實現深拷貝。

更直白的說,序列化是為了實現持久化和網絡傳輸,對象是應用層的東西,不同的語言(比如:java,go,python)創建的對象還不一樣,實現持久化和網絡傳輸的載體不認這些對象。

3. 序列化的原理分析

Java中的序列化是通過實現java.io.Serializable接口來實現的。這個接口是一個標記接口,意味著它本身沒有任何方法,只是用來標記這個類的對象是可序列化的。

當你序列化一個對象時,Java會將對象的所有非瞬態(transient)和非靜態字段的值轉換成字節流。這包括對象的基本數據類型、引用類型,甚至是繼承自父類的字段。

序列化的步驟

  1. 實現Serializable接口:你的類需要實現這個接口。
  2. **創建ObjectOutputStream**:用于將對象轉換成字節流。
  3. 調用writeObject方法:將對象寫入輸出流。
  4. 關閉流:別忘了關閉流以釋放資源。

反序列化的步驟大致相同,只不過是使用ObjectInputStreamreadObject方法。

4. 示例演示

讓我們通過一個簡單的例子來看看實際操作是怎樣的。

定義一個可序列化的類

import java.io.Serializable;

publicclass User implements Serializable {
    privatestaticfinallong serialVersionUID = 1L// 推薦定義序列化版本號
    private String name;
    privateint age;
    privatetransient String password; // transient字段不會被序列化

    public User(String name, int age, String password) {
        this.name = name;
        this.age = age;
        this.password = password;
    }

    // 省略getter和setter方法

    @Override
    public String toString() {
        return"User{name='" + name + "', age=" + age + ", password='" + password + "'}";
    }
}

序列化對象

import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectOutputStream;

publicclass SerializeDemo {
    public static void main(String[] args) {
        User user = new User("Alice"30"secret123");

        try (FileOutputStream fileOut = new FileOutputStream("user.ser");
             ObjectOutputStream out = new ObjectOutputStream(fileOut)) {
             
            out.writeObject(user);
            System.out.println("對象已序列化到 user.ser 文件中.");
        } catch (IOException i) {
            i.printStackTrace();
        }
    }
}

運行上述代碼后,你會發現當前目錄下生成了一個名為user.ser的文件,這就是序列化后的字節流。

反序列化對象

import java.io.FileInputStream;
import java.io.IOException;
import java.io.ObjectInputStream;

publicclass DeserializeDemo {
    public static void main(String[] args) {
        User user = null;

        try (FileInputStream fileIn = new FileInputStream("user.ser");
             ObjectInputStream in = new ObjectInputStream(fileIn)) {
             
            user = (User) in.readObject();
            System.out.println("反序列化后的對象: " + user);
        } catch (IOException | ClassNotFoundException i) {
            i.printStackTrace();
        }
    }
}

運行這段代碼,你會看到輸出:

反序列化后的對象: User{name='Alice', age=30, password='null'}

注意到password字段為空,這是因為它被聲明為transient,在序列化過程中被忽略了。

5. 常見問題與注意事項

serialVersionUID是干嘛的?

serialVersionUID是序列化時用來驗證版本兼容性的一個標識符。如果你不顯式定義它,Java會根據類的結構自動生成。但為了避免類結構變化導致序列化失敗,建議手動定義一個固定的值。

繼承關系中的序列化

如果一個類的父類沒有實現Serializable接口,那么在序列化子類對象時,父類的字段不會被序列化。反序列化時,父類的構造函數會被調用初始化父類部分。

處理敏感信息

使用transient關鍵字可以防止敏感信息被序列化,比如密碼字段。此外,你也可以自定義序列化邏輯,通過實現writeObjectreadObject方法來更精細地控制序列化過程。

6. 總結

本文,我們深入淺出地探討了Java中的序列化和反序列化,從基本概念到原理分析,再到實際的代碼示例,希望你對這兩個重要的技術點有了更清晰的理解。

為什么需要序列化和反序列化?

最直白的說,如果不進行持久化和網絡傳輸,根本不需要序列化和反序列化。如果需要實現持久化和網絡傳輸,就必須序列化和反序列化,因為對象是應用層的東西,不同的語言(比如:java,go,python)創建的對象還不一樣,實現持久化和網絡傳輸的載體根本不認這些對象。


閱讀原文:原文鏈接


該文章在 2025/5/6 12:12:09 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

黄频国产免费高清视频,久久不卡精品中文字幕一区,激情五月天AV电影在线观看,欧美国产韩国日本一区二区
日本婬片在线视频 | 亚洲精品在线中文视频 | 久久青草一区二区三区 | 亚洲AV乱码一区二区三区女同 | 中文字字幕乱码在线观看精品 | 亚洲综合网站精品一区二区 |