一、使用背景
众所周知,Java对象是存储在JVM堆内存中的,没有JVM或者JVM停止运行的时候想要存储或者传输Java对象,就需要用序列化将Java对象持久化为本地文件。在网络传输、RMI中应用广泛。
二、序列化定义
序列化是将对象的状态信息转化为可存储或者可传输的形式的过程,是一种对象持久化的手段。
三、Java实现序列化的方式
1、Java类通过实现java.io.Serializable接口来开启其序列化功能,没有实现这个类的接口不能序列化或者反序列化。控制某些字段不想被序列化而暴露可以使用transient关键字
2、另外一种实现方式就是实现java.io.Externalizable接口,需要用户自己实现writeExternal和readExternal方法,
class User implements Externalizable { private static final long serialVersionUID = 1L; private String name; private int age; public User() { } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return "User[name: " + this.name + ", age: " + this.age + "]"; } @Override public void writeExternal(ObjectOutput out) throws IOException { out.writeObject(name); out.writeObject(age); } @Override public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException { this.name = (String) in.readObject(); } }
四、反序列的注意事项
1、serialVersionUID不一致会导致反序列化失败
2、反序列化需要类提供无参构造函数