Serialversionuid: Serialization is to maintain version compatibility, that is, during version upgrade, deserialization still maintains the uniqueness of objects.
There are two generation methods:
One is the default 1l, for example, Private Static final long serialversionuid = 1l;
One is to generate a 64-bit hash field based on the class name, Interface Name, member method, and attribute. For example:
Private Static final long serialversionuid = xxxxl;
When a class implements the serializable interface, if serialversionuid is not defined, eclipse will provide this
The prompt function tells you to define it. Click the "warning" icon in the class in eclipse, and eclipse will
Two automatic generation methods are provided. If you do not want to define it, it is also set in eclipse.
You can disable it as follows:
Window ==> preferences ==> Java ==> compiler ==> error/warnings ==>
Potential Programming Problems
Change the value of serializable class without serialversionuid to ignore.
If you do not consider compatibility issues, turn it off, but this function is good. If serializable is implemented in any category, if serialversionuid is not added, eclipse will give you a warning that this serialversionuid is backward compatible for this type of serializable.
If your class serialized is stored on the hard disk, but then you change the field of the category (increase, decrease, or rename), when you deserialize, an exception will occur, this will cause incompatibility issues.
However, when the serialversionuid is the same, it will deserialize different fields with the default value of type to avoid incompatibility issues.