1.什么是序列化

序列化指堆内存中的java对象数据,通过某种方式把对存储磁盘文件中,或者传递给其他网络节点(网络传输)。这个过程称为序列化,通常是指将数据结构或对象转化成二进制的过程.

2.序列化使用场景

由序列化的定义,我们就可以知道其使用场景




总结: 序列化使用场景都是涉及到将对象转化成二进制,因为序列化保证了能够成功读取到保存的对象

3.如何实现序列化

实现Serializable 接口即可

public class Student implements Serializable{
    private static final long serialVersionUID = -2917451049380897797L;
    long id;
    String name;
}

注意点:serialVersionUID记得写(ideal可以配置自动生成),具体原因 看第四点

4.序列版本UID serialVersionUID

java的序列化机制是通过判断运行时类的serialVersionUID来验证版本一致性的,在进行反序列化时,JVM会把传进来的字节流中的serialVersionUID与本地实体类中的serialVersionUID进行比较,如果相同则认为是一致的,便可以进行反序列化,否则就会报序列化版本不一致的异常

若我们类中 没有显示定义serialVersionUID 类型为long 的变量,JVM在编译的时候会自动生成一个serialVersionUID作为序列化版本比较,这种情况下,只有同一次编译生成的class才会生成相同的serialVersionUID。若后续我们在该类中添加其他的字段,这个时候再反序列化时便会出现serialVersionUID不一致,导致反序列化失败。

5序列化的一些规则


  • transient修饰的变量不会被序列化
  • 当一个父类实现序列化子类自动实现序列化,不需要显式实现Serializable接口。
  • 当一个对象的实例变量引用其他对象,序列化该对象时也把引用对象进行序列化

如果父类没有实现Serializable接口,没有提供默认构造函数,那么子类的序列化会出错

如果父类没有实现Serializable接口,提供了默认的构造函数,那么子类可以序列化父类的成员变量不会被序列化

如果父类实现了Serializable接口,则父类和子类都可以序列化。