实体类Serializable 接口的作用和必要性

       在Java Web编程中,很多实体类会实现Serializable 接口,但是很多实体在使用中并没有序列化也能正常使用。

       定义:把对象转换为字节序列的过程称为对象的序列化

                 把字节序列恢复为对象的过程称为对象的反序列化

       那么Serializable 接口有什么作用呢?

       Serializable作为序列化的一种方式。序列化可以理解为一种机制,按照一定的格式将Java 对象的某种状态转成介质可以接受的形式,以便存储或传输。

       序列化实现将Java 对象相关的类信息、属性及属性值等等保存起来,便于存储和传输。

      序列化的作用可以总结以下:

(1)提供一种简单又可拓展的对象保存恢复机制

(2)对于远程调用,能方便对对象进行编码和解码,就像实现对象直接传输

(3)可以将对象持久化到介质中,就像实现对对象直接存储。

(4)允许对象自定义外部存储的格式。

序列化的简单理解方式:

序列化的过程,就是一个“freeze”的过程,它将一个对象freeze(冷冻)住,然后进行存储,等到再次需要的时候,再将这个对象de-freeze就可以立即使用。

我们以为的没有进行序列化,其实是在声明的各个不同变量的时候,由具体的数据类型帮助我们实现了序列化操作。

如果有人打开过Serializable接口的源码,就会发现,这个接口其实是个空接口,那么这个序列化操作,到底是由谁去实现了呢?其实,看一下接口的注释说明就知道,当我们让实体类实现Serializable接口时,其实是在告诉JVM此类可被序列化,可被默认的序列化机制序列化。



例子:

@Data
@ToString
public class UserRole implements Serializable {

    private static final long serialVersionUID = -6056129805075132981L;

    private int id;

    private int user_id;

    private int role_id;
}

一个实体类User实现Serializable接口,并且定义了serialVersionUID变量。

serialVersionUID是用来辅助对象的序列化与反序列化的,原则上序列化后的数据当中的serialVersionUID与当前类当中的serialVersionUID一致,那么该对象才能被反序列化成功。

工作机制:在序列化的时候系统将serialVersionUID写入到序列化的文件中去,当反序列化的时候系统会先去检测文件中的serialVersionUID是否跟当前的文件的serialVersionUID是否一致,如果一直则反序列化成功,否则就说明当前类跟序列化后的类发生了变化。

上一篇:idea中实现Serializable提示生成serialVersionUID(序列化id)设置


下一篇:flink jdbc分库分表