您好,登錄后才能下訂單哦!
本篇內容介紹了“Java對象的序列化和反序列化舉例分析”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
1、什么是序列化與反序列化?
序列化:指把堆內存中的 Java 對象數據,通過某種方式把對象存儲到磁盤文件中或者傳遞給其他網絡節點(在網絡上傳輸)。這個過程稱為序列化。通俗來說就是將數據結構或對象轉換成二進制串的過程
反序列化:把磁盤文件中的對象數據或者把網絡節點上的對象數據,恢復成Java對象模型的過程。也就是將在序列化過程中所生成的二進制串轉換成數據結構或者對象的過程
2、為什么要做序列化?
①、在分布式系統中,此時需要把對象在網絡上傳輸,就得把對象數據轉換為二進制形式,需要共享的數據的 JavaBean 對象,都得做序列化。
②、服務器鈍化:如果服務器發現某些對象好久沒活動了,那么服務器就會把這些內存中的對象持久化在本地磁盤文件中(Java對象轉換為二進制文件);如果服務器發現某些對象需要活動時,先去內存中尋找,找不到再去磁盤文件中反序列化我們的對象數據,恢復成 Java 對象。這樣能節省服務器內存。
3、Java 怎么進行序列化?
①、需要做序列化的對象的類,必須實現序列化接口:Java.lang.Serializable 接口(這是一個標志接口,沒有任何抽象方法),Java 中大多數類都實現了該接口,比如:String,Integer
②、底層會判斷,如果當前對象是 Serializable 的實例,才允許做序列化,Java對象 instanceof Serializable 來判斷。
③、在 Java 中使用對象流來完成序列化和反序列化
ObjectOutputStream:通過 writeObject()方法做序列化操作
ObjectInputStream:通過 readObject() 方法做反序列化操作
第一步:創建一個 JavaBean 對象
第二步:使用 ObjectOutputStream 對象實現序列化
我們打開a.txt文件,發現里面的內容亂碼,注意這不需要我們來看懂,這是二進制文件,計算機能讀懂就行了。
錯誤一:如果新建的 Person 對象沒有實現 Serializable 接口,那么上面的操作會報錯:
第三步:使用ObjectInputStream 對象實現反序列化
反序列化的對象必須要提供該對象的字節碼文件.class
問題1:如果某些數據不需要做序列化,比如密碼,比如上面的年齡?
解決辦法:在字段面前加上 transient
那么我們在反序列化的時候,打印出來的就是Person [name=vae, age=0],整型數據默認值為 0
問題2:序列化版本問題,在完成序列化操作后,由于項目的升級或修改,可能我們會對序列化對象進行修改,比如增加某個字段,那么我們在進行反序列化就會報錯:
解決辦法:在 JavaBean 對象中增加一個 serialVersionUID 字段,用來固定這個版本,無論我們怎么修改,版本都是一致的,就能進行反序列化了
/**
* 序列化ID
*/
private static final long serialVersionUID = 8656128222714547171L;
“Java對象的序列化和反序列化舉例分析”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。