serializable引发的序列化、反序列化

最初关注点

编辑代码时,在一个java对象中看到有
private static final long serialVersionUID = 1L;
这样一句话,且在对象字段的最后有
@Override protected Serializable pkVal() { return this.guid; }
这样的字样。
观察了一下其他的对象,大同小异,且值都为1L,就查了一下

序列化与反序列化的概念

  • 序列化:序列化 (Serialization)是将对象的状态信息转换为可以存储或传输的形式的过程。在序列化期间,对象将其当前状态写入到临时或持久性存储区。以后,可以通过从存储区中读取或反序列化对象的状态,重新创建该对象。

  • 反序列化:反序列化是将对象的可以存储或传输的形式转换为状态信息的过程。

    个人理解,就是对象与字节序列相互转化的过程。而serialVersionUID就是序列换和反序列化时确认的标志,相当于调动军马的虎符,两者合二为一才能达到动用大军的效果,而此处是一致才不会产生错误。
    而若两者不一致,就会报错,错误为InvalidClassException,但不是所有的 InvalidClassException错误都是这个原因造成的哈。

序列化与反序列化应用的情况

  • 存储
  • 传输
  • 交互接口
    有点抽象了,可以研究下。
    tomcat服务器在关闭时,会将session序列化保存到名为session.ser的文件中,这一过程称为钝化。在tomcat重启时,反序列化session.ser文件,这一过程称为活化。目的是解决在tomcat关闭时访问用户保存在session中的数据丢失。

serializable取值

一般有两种:

  • 默认为1L,
  • 可根据类名、接口名、成员方法及属性等生成一个64位的哈希字段,但其值也要是Long值。

猜你喜欢

转载自blog.csdn.net/qq_44681872/article/details/124057783