JAVA 类中 serialVersionUID 的作用

本文介绍了在Java中实现Serializable接口时serialVersionUID的作用及其重要性。包括如何生成版本ID号、为何需要定义它以及如何避免兼容性问题。还提供了关闭Eclipse提示的方法。
摘要由CSDN通过智能技术生成

通常在继承 Serializable 接口的类,Eclipse 会提示需要定义一个版本 ID 号,例如可以自动生成:
private static final long serialVersionUID = 791446515840133966L;

有两种生成方式
一个是默认的1L,比如:private static final long serialVersionUID = 1L;
一个是根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段,比如:
private static final long serialVersionUID = xxxxL;

当你一个类实现了Serializable接口,如果没有定义serialVersionUID,Eclipse会提供这个提示功能告诉你去定义。

如果不想定义它,在Eclipse的设置中也可以把它关掉的,设置如下:
Window ==> Preferences ==> Java ==> Compiler ==> Error/Warnings ==> Potential programming problems
将 Serializable class without serialVersionUID 的 warning 改成 ignore 即可。

定义版本 ID 号以后,序列化时会保持版本的兼容性,即在版本升级时反序列化仍保持对象的唯一性。

如果你的类 Serialized 存到硬盘上面后,可是后来你却更改了类别的field(增加或减少或改名),当 Deserialize 时就会出现异常,这样就会造成不兼容性的问题。

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

在JDK中,可以利用JDK的bin目录下的serialver.exe工具产生这个serialVersionUID,对于Test.class,执行命令:serialver Test。
为了在反序列化时,确保类版本的兼容性,最好在每个要序列化的类中加入 private static final long serialVersionUID这个属性,具体数值自己定义。这样,即使某个类在与之对应的对象已经序列化出去后做了修改,该对象依然可以被正确反序列化。

否则,如果不显式定义该属性,这个属性值将由JVM根据类的相关信息计算,而修改后的类的计算结果与修改前的类的计算结果往往不同,从而造成对象的反序列化因为类版本不兼容而失败。
不显式定义这个属性值的另一个坏处是,不利于程序在不同的JVM之间的移植。因为不同的编译器实现该属性值的计算策略可能不同,从而造成虽然类没有改变,但是因为JVM不同,出现因类版本不兼容而无法正确反序列化的现象出现。

 

 

以上内容转自网络:http://blog.sina.com.cn/s/blog_8020e411010126pr.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值