关于Java实体类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是否一致,如果一直则反序列化成功,否则就说明当前类跟序列化后的类发生了变化。

  到此这篇关于关于Java实体类Serializable序列化接口的作用和必要性解析的文章就介绍到这了,更多相关Java序列化接口Serializable内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

  您可能感兴趣的文章: