版权声明:本文为博主fbysss原创文章,转载请注明出处

作者:fbysss
msn:jameslastchina@hotmail.com 
blog:blog.csdn.NET/fbysss
声明:本文由fbysss原创,转载请注明出处
关键字:SerialVersionUid 序列化

一、前言

SerialVersionUid,简言之,其目的是序列化对象版本控制,有关各版本反序列化时是否兼容。如果在新版本中这个值修改了,新版本就不兼容旧版本,反序列化时会抛出InvalidClassException异常。如果修改较小,比如仅仅是增加了一个属性,我们希望向下兼容,老版本的数据都能保留,那就不用修改;如果我们删除了一个属性,或者更改了类的继承关系,必然不兼容旧数据,这时就应该手动更新版本号,即SerialVersionUid。

关于其定义,可参考JDK文档:http://download.oracle.com/javase/1.5.0/docs/api/java/io/Serializable.html

二、问题

1.如果不显式设置SerialVersionUid,有什么后果?

jdk文档中有解释,建议我们显式声明,因为如果不声明,JVM会为我们自动产生一个值,但这个值和编译器的实现相关,并不稳定,这样就可能在不同JVM环境下出现反序列化时报InvalidClassException异常。

...it is strongly recommended that all serializable classes explicitly declare serialVersionUID values, since the default serialVersionUID computation is highly sensitive to class details that may vary depending on compiler implementations...

2.两种SerialVersionUid有什么区别?

在Eclipse中,提供两种方式让我们快速添加SerialVersionUid。

add default serial version ID
Adds a default serial version ID to the selected type
Use this option to add a user-defined ID in combination with custom serialization code if the type did undergo structural change since its first release.

add generated serial version ID:
Adds a generated serial version ID to the selected type
Use this option to add a compiler-generated ID if the type didnot undergo structural change since its first release.

一种就是1L,一种是生成一个很大的数,这两种有什么区别呢?

看上去,好像每个类的这个类不同,似乎这个SerialVersionUid在类之间有某种关联。其实不然,两种都可以,从JDK文档也看不出这一点。我们只要保证在同一个类中,不同版本根据兼容需要,是否更改SerialVersionUid即可。

对于第一种,需要了解哪些情况是可兼容的,哪些根本就不兼容。 参考文档:http://Java.sun.com/j2se/1.4/pdf/serial-spec.pdf

在可兼容的前提下,可以保留旧版本号,如果不兼容,或者想让它不兼容,就手工递增版本号。

1->2->3.....

第二种方式,是根据类的结构产生的hash值。增减一个属性、方法等,都可能导致这个值产生变化。我想这种方式适用于这样的场景:

开发者认为每次修改类后就需要生成新的版本号,不想向下兼容,操作就是删除原有serialVesionUid声明语句,再自动生成一下。

个人认为,一般采用第一种就行了,简单。第二种能够保证每次更改类结构后改变版本号,但还是要手工去生成,并不是修改了类,会提示你要去更新这个SerialVersionUid,所以虽然看上去很cool,实际上让人很迷惑。

参考:

1.一篇较好的关于serialVesionUid的说明:

http://www.mkyong.com/java-best-practices/understand-the-serialversionuid/

2.serialVesionUid相关讨论

http://stackoverflow.com/questions/888335/why-generate-long-serialversionuid-instead-of-a-simple-1l

3.compiler-generated ID生成算法

http://java.sun.com/javase/6/docs/platform/serialization/spec/class.html#4100

其他相关问题:

hibernate的持久化,这个一般指的是将数据持久化到数据库,和序列化并没有直接关系。

Hibernate的POJO也并不要求必须实现Serializable接口,但是,作为系统扩展考虑,应该把PO都实现Serializable接口,因为如果这些对象需要缓存到磁盘上,或者在分布式环境下使用,就必须序列化,最常见的例子就是ehcache、Memcached。key和value中的对象都必须是序列化的对象。

Java序列化中的SerialVersionUid相关推荐

  1. 深入理解Java序列化中的SerialVersionUid

    作者:fbysss msn:jameslastchina@hotmail.com  blog:blog.csdn.net/fbysss 声明:本文由fbysss原创,转载请注明出处 关键字:Seria ...

  2. Java序列化报错serialVersionUID不一致

    反序列化报错:java.io.InvalidClassException: com.*.*;   local class incompatible: stream classdesc serialVe ...

  3. Java序列化,碰到serialVersionUID不一致怎么处理?

    你知道的越多,不知道的就越多,业余的像一棵小草! 成功路上并不拥挤,因为坚持的人不多. 编辑:业余草 juejin.cn/post/6961229793056686117 推荐:https://www ...

  4. Java序列化之serialVersionUID

    Java序列化之serialVersionUID 今天讲一讲Java对象中的serialVersionUID,先从序列化讲起. 什么是序列化 序列化,简单的说,就是将一个对象转化(编码)成可以传输的输 ...

  5. java基础(十)-----Java 序列化的高级认识

    将 Java 对象序列化为二进制文件的 Java 序列化技术是 Java 系列技术中一个较为重要的技术点,在大部分情况下,开发人员只需要了解被序列化的类需要实现 Serializable 接口,使用 ...

  6. 深入理解JAVA序列化

    2019独角兽企业重金招聘Python工程师标准>>> 如果你只知道实现 Serializable 接口的对象,可以序列化为本地文件.那你最好再阅读该篇文章,文章对序列化进行了更深一 ...

  7. Java 序列化的高级认识

    这篇文章来自:http://www.ibm.com/developerworks/cn/java/j-lo-serial/index.html 引言 将 Java 对象序列化为二进制文件的 Java ...

  8. 【通知】+ java基础提升篇:Java 序列化的高级认识

    点击上方"好好学java",选择"置顶公众号" 优秀学习资源.干货第一时间送达! 好好学java java知识分享/学习资源免费分享 关注 精彩内容 你所需要的 ...

  9. java基础提升篇:Java 序列化的高级认识

    如果你只知道实现 Serializable 接口的对象,可以序列化为本地文件.那你最好再阅读该篇文章,文章对序列化进行了更深一步的讨论,用实际的例子代码讲述了序列化的高级认识,包括父类序列化的问题.静 ...

最新文章

  1. 什么是BeanShell?
  2. python 自带的range是不能实现对小数的操作的,如果要对小数操作可以使用numpy...
  3. a+b 第一个JAVA
  4. Mcad学习笔记之序列化(2进制和Soap序列化)
  5. 机器学习基础(HGL的机器学习笔记1)
  6. awk学习实战-原创
  7. LeetCode:63. 不同路径 II
  8. Mysql的安装和配置
  9. Intel 64/x86_64/IA-32/x86处理器 - 通用指令(9/E) - 比特位操控指令(BMI1 BMI2)
  10. 2018.09.07阿里巴巴笔试题
  11. python 学习(pip工具的安装)
  12. 数据结构视频教程 -《[猎豹网校]数据结构与算法_C语言》
  13. 推荐10本必读的心理学书籍
  14. 建筑业加速提高智能建造水准
  15. 【数理逻辑三】命题逻辑及形式系统【上】
  16. 工程师文化:BAT为什么不喊老板?
  17. 吊炸天,Spring Security还有这种用法
  18. SAP那些事-职业篇-36-从“固定资产清理”科目说开去
  19. Adobenbsp;photoshopnbsp;cs5,dreamweavernbsp;…
  20. CF633C Spy Syndrome 2 ACA+DP

热门文章

  1. 如何做好需求变更管理?——需求变更流程规范
  2. MySQL主从复制: MHA
  3. mysql操作SQL语句
  4. Windows下架设SVN服务
  5. 简单工厂模式(静态工厂模式)
  6. 请谨慎设置WinForm控件DataGridView列的AutoSizeMode属性
  7. a:10 GET http://localhost:8080/static/js/xxx.js net::ERR_ABORTED 404
  8. web平台安装程序_来了来了!开源车间调度平台正式上线!
  9. 爆炸的符卡洋洋洒洒(01背包)
  10. 数据自动机之如何使用CYaRon造数据