本文主要是介绍关于实现Serializable 接口的类中的SerialVersionUID问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
当一个类实现了Serializable接口时,表明该类可以被序列化,这个时候Eclipse会要求你为该类定义一个字段,该字段名字为serialVersionUID,类型为long,提示信息如下:The serializable clss Student4 does not declare a static final serialVersionUID field of type long
有两种方式可以解决这个问题(你可以随便写一个,在Eclipse中它替你生成一个,有两种生成方式):
1、一个是默认的1L,比如:private static final long serialVersionUID = 1L;
2、另一个是根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段,比如:private static final long serialVersionUID = 8940196742313994740L;之类的。
这两种方式通过在警告上面的点击ctrl+1也可以看到,里面也有。
当你一个类实现了Serializable接口,如果没有定义serialVersionUID,Eclipse会提供这个提示功能告诉你去定义之。
在Eclipse中点击类中warning的图标(或是光标移上去,然后点击crtl+1)一下【即那个黄色的图标】,Eclipse就会自动给定两种生成的方式,如上面所述。如果不想定义它,在Eclipse的设置中也可以把它关掉,设置如下:
Window==Preferences==Java==Compiler==Error/Warnings==Potential programming problems
将Serializable class without serialVersionUID的warning改成ignore即可。
如果你没有考虑到兼容性问题时,就把它关掉,不过有这个功能是好的,只要任何类别实现了Serializable这个接口的话,如果没有加入serialVersinoUID,Eclipse都会给你warning提示,这个serialVersionUID为了让该类别Serializable(序列化后)向后兼容。
如果你的对象序列化后存到硬盘上面后,可是后来你却更改了类的field(增加或减少或改名),当你反序列化时,就会出现Exception的,这样就会造成不兼容性的问题。
但当serialVersionUID相同时(检查序列化的那个对象的serialVersionUID和已有的类里面的serialVersionUID是否相同),它就会将不一样的field以type的缺省值Deserialize(初始化),这个可以避开不兼容性的问题,就不会报错了。
这篇关于关于实现Serializable 接口的类中的SerialVersionUID问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!