例如,jdk源码NTLMException类的定义,其中涉及到了序列化注解Serial和序列化版本号字段serialVersionUID:
序列化注解java.io.Serial:
序列化注解java.io.Serial是在javaSE-14版本引入的。通常注解实现了序列化类的序列化相关的函数和字段,这样可以让编译器在编译的时候检查序列化相关的函数、字段的声明,提前发现错误。
5个序列化相关的方法:
2个序列化相关的字段:
序列版本号字段serialVersionUID:
这个版本号的作用是反序列化的时候检查,检查序列化对象的接收者和发送者是否使用了相同的版本号,如果版本号不同,会导致出现 InvalidClassException异常。
如果在程序中没有明确定义这个字段,那么程序在序列化的时候会自动生成;如果程序中明确了定义这个字段,那么就使用定义的这个版本号。
强烈建议在程序中明确定义。因为如果自动生成这个字段,会依赖序列化类的很多方面,对类的细节敏感,而类的细节可能因为编译器实现而变化。
如果明确定义,这个字段名称为serialVersionUID,类型是long,用static, final修饰。另外,强烈建议加上private修饰。因为如果用private修饰,那么serialVersionUID仅对当前类有效,不能被子类继承。
有公司的编程规范就要求:序列化类新增属性时,不要修改 serialVersionUID 字段,避免反序列失败;如果完全不兼容升级,避免反序列化混乱,那么要修改 serialVersionUID 值。