Java序列化随记
序列化简介:
程序中的对象并不只是存在内存中,还需要传输网络,或者保存起来下次再加载出来用,因此需要Java序列化技术。
Java序列化技术正是将对象转变成一串由二进制字节组成的数组,可以通过将二进制数据保存到磁盘或者传输网络,磁盘或者网络接收者可以在对象的属类的模板上来反序列化类的对象,达到对象持久化的目的。
如何序列化一个对象?
首先要序列化一个对象,这个对象所在类就必须实现Java序列化的接口:java.io.Serializable。
类实现序列化接口:
1 import java.io.Serializable; 2 3 public class User implements Serializable { 4 5 private String username; 6 private String address; 7 public String getUsername(){ 8 return username; 9 } 10 11 public void setUsername(String username) { 12 this.username = username; 13 } 14 15 public String getAddress() { 16 return address; 17 } 18 19 public void setAddress(String address) { 20 this.address = address; 21 } 22 23 @Override 24 public String toString() { 25 return "User{" + 26 "username='" + username + '\'' + 27 ", address='" + address + '\'' + 28 '}'; 29 } 30 }
序列化/反序列化
1 import org.apache.commons.lang3.SerializationUils; 2 public class Test { 3 public static void main(String[] args) { 4 User user = new User(); 5 user.setUsername("YJ"); 6 user.setAddress("China"); 7 //序列化对象 8 byte[] bytes = SerialzationUtils.serialize(user); 9 10 //反序列化 11 User user1 = SerializationUtils.deserialize(bytes); 12 System.out.println(user1); 13 } 14 }
输出:
User{username='YJ',address='China'}
这个例子就是通过序列化对象字节到内存然后反序列化,当然工具类里面也提供了序列化磁盘然后再反序列化的方法,原理都是一样的,只是目标地不一样。
序列化总结:
-
序列化对象必须实现序列化接口。
-
序列化对象里面的属性是对象的话也要实现序列化接口。
-
类的对象序列化后,类的序列化ID不能轻易修改,不然反序列化会失败。
-
类的对象序列化后,类的属性有增加或者删除不会影响序列化,只是值会丢失。
-
如果父类序列化了,子类会继承父类的序列化,子类无需添加序列化接口。
-
如果父类没有序列化,子类序列化了,子类中的属性能正常序列化,但父类的属性会丢失,不能序列化。
-
用Java序列化的二进制字节数据只能由Java反序列化,不能被其他语言反序列化。如果要进行前后端或者不同语言之间的交互一般需要将对象转变成Json/Xml通用格式的数据,再恢复原来的对象。
-
如果某个字段不想序列化,在该字段前加上transient关键字即可。