JDK源码阅读(五)java.io.Serializable接口

2023-07-12,,

package java.io;

public interface Serializable {
}

(1)实现Serializable接口的类,将会被提示提供一个 serialVersionUID

注意点一、序列化时为了保持版本的兼容性,即在版本升级时反序列化仍保持对象的唯一性。
     有两种生成方式:
              ①一个是默认的1L,比如:private static final long serialVersionUID = 1L;
              ②一个是根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段,比如:
              private static final   long     serialVersionUID = xxxxL;

注意点二、当你一个类实现了Serializable接口,如果没有定义serialVersionUID,Eclipse会提供这个提示功能告诉你去定义 。在Eclipse中点击类中warning的图标一下,Eclipse 就会自动给定两种生成的方式。如果不想定义它,在Eclipse的设置中也可以把它关掉的,设置如下:

Window -> Preferences -> Java -> Compiler -> Error/Warnings ->Potential programming problems
             将Serializable class without serialVersionUID的warning改成ignore即可。

注意点三、如果你没有考虑到兼容性问题时,就把它关掉,不过有这个功能是好的,只要任何类别实现了

         Serializable这个接口的话,如果没有加入 serialVersionUID,Eclipse都会给你warning提示,这个

             serialVersionUID为了让该类别 Serializable向后兼容。

如果你的类Serialized存到硬盘上面后,可是后来你却更改了类别的field(增加或减少或改名),当你

Deserialize时,就会出现Exception的,这样就会造成不兼容性的问题。

但当serialVersionUID相同时,它就会将不一样的field以type的预设值Deserialize,可避开不兼容性 问题。

JDK源码阅读(五)java.io.Serializable接口的相关教程结束。

《JDK源码阅读(五)java.io.Serializable接口.doc》

下载本文的Word格式文档,以方便收藏与打印。