关于Java序列化你应该知道的一切
轉載自?關于Java序列化你應該知道的一切
什么是序列化
我們的對象并不只是存在內存中,還需要傳輸網絡,或者保存起來下次再加載出來用,所以需要Java序列化技術。
Java序列化技術正是將對象轉變成一串由二進制字節組成的數組,可以通過將二進制數據保存到磁盤或者傳輸網絡,磁盤或者網絡接收者可以在對象的屬類的模板上來反序列化類的對象,達到對象持久化的目的。
怎么序列化一個對象?
要序列化一個對象,這個對象所在類就必須實現Java序列化的接口:java.io.Serializable。
1、類添加序列化接口
import java.io.Serializable; public class User implements Serializable{ ? ?private static final long serialVersionUID = -8475669200846811112L; ? ?private String username;private String address; ? ?public String getUsername() {return username;} ? ?public void setUsername(String username) {this.username = username;} ? ?public String getAddress() {return address;} ? ?public void setAddress(String address) {this.address = address;} ? ?@Overridepublic String toString() {return "User{" +"username='" + username + '\'' +", address='" + address + '\'' +'}';} }2、序列化/反序列化
可以借助commons-lang3工具包里面的類實現對象的序列化及反序列化,你沒有必要自己寫。
import org.apache.commons.lang3.SerializationUtils; public class Test { ? ?public static void main(String[] args) {User user = new User();user.setUsername("Java");user.setAddress("China");byte[] bytes = SerializationUtils.serialize(user); ? ? ? ?User u = SerializationUtils.deserialize(bytes);System.out.println(u); ? ?} }輸出:
User{username='Java', address='China'}上例通過序列化對象字節到內存然后反序列化,當然里面也提供了序列化磁盤然后再反序列化的方法,原理都是一樣的,只是目標地不一樣。
序列化注意事項
-
序列化對象必須實現序列化接口。
-
序列化對象里面的屬性是對象的話也要實現序列化接口。
-
類的對象序列化后,類的序列化ID不能輕易修改,不然反序列化會失敗。
-
類的對象序列化后,類的屬性有增加或者刪除不會影響序列化,只是值會丟失。
-
如果父類序列化了,子類會繼承父類的序列化,子類無需添加序列化接口。
-
如果父類沒有序列化,子類序列化了,子類中的屬性能正常序列化,但父類的屬性會丟失,不能序列化。
-
用Java序列化的二進制字節數據只能由Java反序列化,不能被其他語言反序列化。如果要進行前后端或者不同語言之間的交互一般需要將對象轉變成Json/Xml通用格式的數據,再恢復原來的對象。
-
如果某個字段不想序列化,在該字段前加上transient關鍵字即可。
總結
以上是生活随笔為你收集整理的关于Java序列化你应该知道的一切的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 如何查看笔记本的硬件配置?
- 下一篇: Java高级进阶:自定义ClassLoa