最初关注点
编辑代码时,在一个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值。