java类序列化与反序列化版本唯一号serialVersionUID 自动生成方法

/**
* 序列化与反序列化自动生成serialVersionUID唯一值
* 实现序列化接口,点击java 类黄色按钮选择自动生成版本序列化UID值。
*
*/
private static final long serialVersionUID = -212199624406986608L;


serialVersionUID作用:
序列化时为了保持版本的兼容性,即在版本升级时反序列化仍保持对象的唯一性。
有两种生成方式:
一个是默认的1L,比如:private static final long serialVersionUID = 1L;
一个是根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段,比如:
private static final long serialVersionUID = xxxxL;
关于其定义,可参考JDK文档:http://download.oracle.com/javase/1.5.0/docs/api/java/io/Serializable.html

在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/
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java序列化是指将一个Java对象转换成字节序列的过程,以便可以将其存储到文件、数据库或在网络上传输。只有实现了Serializable或Externalizable接口的的对象才能被序列化,否则会抛出异常。 Java反序列化则是将字节序列重新转换成Java对象的过程。通过反序列化,可以从文件、数据库或网络中读取字节序列,并将其转换回原始的Java对象。 Java序列化反序列化有以下几个好处: 1. 数据持久化:通过序列化,可以将对象永久地保存到硬盘上,通常存放在文件中。这样可以实现数据的长期存储和读取。 2. 远程通信:通过序列化反序列化,可以在网络上传送对象的字节序列,实现远程通信。这在分布式系统和客户端-服务器应用中非常有用。 在Java序列化机制中,版本一致性非常重要。当进行反序列化时,JVM会通过比较传来的字节流中的serialVersionUID和本地相应对象的serialVersionUID来验证版本一致性。如果两者相同,就认为是一致的,可以进行反序列化。否则,就会出现序列化版本不一致的异常。 需要注意的是,如果实现了java.io.Serializable接口的没有显式地定义一个名为serialVersionUID的变量,Java序列化机制会根据编译的class自动生成一个serialVersionUID用于序列化版本比较。但是只有同一次编译生成的class才会生成相同的serialVersionUID。因此,在进行序列化反序列化时,确保对象的定义和使用的定义是一致的非常重要。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值