Java 序列化总结.md
生活随笔
收集整理的這篇文章主要介紹了
Java 序列化总结.md
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
概述
- 序列化:將對象寫入到 IO 流中
- 反序列化:從 IO 流中恢復(fù)對象
實現(xiàn)方法
實現(xiàn) Serializable 或者 Externalizable
- Serializable:標記接口,不用實現(xiàn)任何方法,可以指定序列化 ID
- Externalizable:增強的序列化標記接口,提供了 writeExternal 和 readExternal 兩個接口方法,這兩個方法在序列化和反序列化的過程中會被調(diào)用
注意,序列化 ID 只是一個版本號,兩種方法都可以不指定,JVM 會根據(jù)類中的信息自動計算一個序列化版本號。不指定序列化版本號可能存在如下隱患:
- 不同版本的 JVM 可能會有不同的計算規(guī)則,可能會導(dǎo)致類的信息完全一致但是序列化失敗
- 在類中的信息被修改后,由于 JVM 計算出來了不同的版本號,則很可能導(dǎo)致序列化失敗
Serializable 和 Externalizable 的區(qū)別
- 實現(xiàn) Serializable 不用額外實現(xiàn)方法,但是實現(xiàn) Externalizable 必須實現(xiàn) writeExternal 和 readExternal 兩個方法
- 實現(xiàn) Externalizable 必須要提供 public 修飾的無參構(gòu)造器,否則會報錯;Serializable 不需要無參構(gòu)造器
- 實現(xiàn) Externalizable 必須把所有需要序列化的屬性在 writeExternal 中一一手動序列化,所有需要反序列化的屬性在 readExternal 中一一手動反序列化;Serializable 由 JVM 自動完成
Serializable 的擴展點
- 可以實現(xiàn) private void writeObject(ObjectOutputStream out) 來自定義序列化邏輯,注意必須使用完全一致的方法名和 private 修飾符
- 可以實現(xiàn) private void readObject(ObjectInputStream in) 來自定義反序列化邏輯,注意必須使用完全一致的方法名和 private 修飾符
- 當某個屬性上加上了 transient 關(guān)鍵字后,這個屬性將不會被序列化
注意點
- 當一個序列化對象存在一個引用類型的對象時,這個對象也必須是可實例化的(或者加上 transient 關(guān)鍵字),否則會報錯
- 同一對象只會被序列化成二進制流一次,不會重復(fù)序列化
- 單例類被序列化時,需要重寫 readResolve 方法,否則會破環(huán)單例機制
總結(jié)
以上是生活随笔為你收集整理的Java 序列化总结.md的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java读取文件指定位置_Java读取指
- 下一篇: java7 xp版下载64位_JRE7