自动生产serialVersionUID 的方法
2016-07-19 15:23
218 查看
第一次做EE项目,遇见需要自动生产serialVersionUID ,于是百度 ,收集了下得到如下方法
首先,用实体类继承 如下
2,这时候鼠标放在类名上 会提示,有2种生成方式,如下
3,一个是默认的1L,比如:private static final long serialVersionUID = 1L;
一个是根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段, 如下
一种就是1L,一种是生成一个很大的数,这两种有什么区别呢?
看上去,好像每个类的这个类不同,似乎这个SerialVersionUid在类之间有某种关联。其实不然,两种都可以,从JDK文档也看不出这一点。我们只要保证在同一个类中,不同版本根据兼容需要,是否更改SerialVersionUid即可。
对于第一种,需要了解哪些情况是可兼容的,哪些根本就不兼容。 参考文档:http://java.sun.com/j2se/1.4/pdf/serial-spec.pdf
在可兼容的前提下,可以保留旧版本号,如果不兼容,或者想让它不兼容,就手工递增版本号。
1->2->3.....
第二种方式,是根据类的结构产生的hash值。增减一个属性、方法等,都可能导致这个值产生变化。我想这种方式适用于这样的场景:
开发者认为每次修改类后就需要生成新的版本号,不想向下兼容,操作就是删除原有serialVesionUid声明语句,再自动生成一下。
个人认为,一般采用第一种就行了,简单。
第二种能够保证每次更改类结构后改变版本号,但还是要手工去生成,并不是修改了类,会提示你要去更新这个SerialVersionUid,所以虽然看上去很cool,实际上让人很迷惑。
4,最后修改成自己需要继承的类 就完成了
首先,用实体类继承 如下
2,这时候鼠标放在类名上 会提示,有2种生成方式,如下
3,一个是默认的1L,比如:private static final long serialVersionUID = 1L;
一个是根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段, 如下
一种就是1L,一种是生成一个很大的数,这两种有什么区别呢?
看上去,好像每个类的这个类不同,似乎这个SerialVersionUid在类之间有某种关联。其实不然,两种都可以,从JDK文档也看不出这一点。我们只要保证在同一个类中,不同版本根据兼容需要,是否更改SerialVersionUid即可。
对于第一种,需要了解哪些情况是可兼容的,哪些根本就不兼容。 参考文档:http://java.sun.com/j2se/1.4/pdf/serial-spec.pdf
在可兼容的前提下,可以保留旧版本号,如果不兼容,或者想让它不兼容,就手工递增版本号。
1->2->3.....
第二种方式,是根据类的结构产生的hash值。增减一个属性、方法等,都可能导致这个值产生变化。我想这种方式适用于这样的场景:
开发者认为每次修改类后就需要生成新的版本号,不想向下兼容,操作就是删除原有serialVesionUid声明语句,再自动生成一下。
个人认为,一般采用第一种就行了,简单。
第二种能够保证每次更改类结构后改变版本号,但还是要手工去生成,并不是修改了类,会提示你要去更新这个SerialVersionUid,所以虽然看上去很cool,实际上让人很迷惑。
4,最后修改成自己需要继承的类 就完成了
相关文章推荐
- Android开发技术周报 Issue#5
- Android开发技术周报 Issue#6
- UIBezierPath 画线 圆 弧
- UE4流关卡
- Android开发技术周报 Issue#7
- Android开发技术周报 Issue#8
- UE4模型导入基础教程
- Android开发技术周报 Issue#9
- Android开发技术周报 Issue#10
- Android开发技术周报 Issue#11
- 做一个gulp+webpack+vue的单页应用开发架子
- Android开发技术周报 Issue#12
- Android开发技术周报 Issue#13
- Android开发技术周报 Issue#14
- Android开发技术周报 Issue#15
- 2015年最全的移动WEB前端UI框架
- Android开发技术周报 Issue#16
- Android开发技术周报 Issue#17
- Android开发技术周报 Issue#18
- javax.jms.JMSException: Failed to build body from content. Serializable class not available to broke