JAVA 版本号作用,private static final long serialVersionUID = 6092916278939819373L;??

Python018

JAVA 版本号作用,private static final long serialVersionUID = 6092916278939819373L;??,第1张

序列化时为了保持版本的兼容性,即在版本升级时反序列化仍保持对象的唯一性。

有两种生成方式:

一个是默认的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,可避开不兼容性问题。

原因:执行环境中的JRE版本与被执行代码的class文件不兼容,一本是因为编译Java代码时使用的JRE版本比代码运行环境的JRE版本要高。我们所遇到的问题正式这样,有的同学的Mac机上模式使用的Java 7,而远程Linux服务器上我们是默认使用Java 6.

Java版本的主版本号如下:

J2SE 8 = 52,

J2SE 7 = 51,

J2SE 6.0 = 50,

版权声明:本文为CSDN博主「常一二」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/weixin_36193839/article/details/114689841

1、(1)Java SE:各应用平台的基础,桌面系统的Java 2平台标准版,桌面系统应用平台。

(2)Java EE:创建服务器应用程序和服务的Java 2平台企业版,企业web服务应用平台。

(3)Java ME:适用于小型设备和智能卡的Java 2平台Micro版,移动平台。

2、发布日期从1997年9月12日至2011年7月28日的,其版本号及名称变迁如下:JDK 1.1.4、JDK 1.1.5、JDK 1.1.6、JDK 1.1.7、JDK 1.1.8、J2SE 1.2、J2SE 1.2.1、J2SE 1.2.2、J2SE 1.3、J2SE 1.3.1、J2SE 1.4.0、J2SE 1.4.1、J2SE 1.4.2、J2SE 5.0、Java SE 6、Java SE 7。