java—为什么在父类中反序列化时不抛出invalidclassexception

bzzcjhmw  于 2021-07-06  发布在  Java
关注(0)|答案(1)|浏览(444)

为什么在尝试将子类读入父类变量时没有错误?我认为在创建一个已经被编译器读取的对象之前 serialVersionUID 两个类(变量类和已读取的类)的 serialVersionUID 不相等 InvalidClassException 被抛出。我也是 A 类和 B 班级有相同的 serialVersionUID ?

  1. import java.io.*;
  2. class A {}
  3. class B extends A implements Serializable {}
  4. public class Test
  5. {
  6. public static void main(String[] args) throws IOException, ClassNotFoundException
  7. {
  8. FileOutputStream fileOutputStream = new FileOutputStream("b.bin");
  9. ObjectOutputStream objectOutputStream = new ObjectOutputStream(fileOutputStream);
  10. B b1 = new B();
  11. objectOutputStream.writeObject(b1);
  12. objectOutputStream.close();
  13. FileInputStream fileInputStream = new FileInputStream("b.bin");
  14. ObjectInputStream objectInputStream = new ObjectInputStream(fileInputStream);
  15. A a1 = (A) objectInputStream.readObject(); // why I don't have an InvalidClass Exception here
  16. objectInputStream.close();
  17. }
  18. }
lg40wkob

lg40wkob1#

不,这两个班的课程不一样 serialVersionUID . 没有引发异常,因为类 B 可以成功重建。例如,当 serialVersionUID 不匹配或何时匹配 A 不会实现默认构造函数。
当你反序列化 objectInputStream.readObject() ,安 Object 可以安全地投回 B . 自 B 延伸 A ,可以向上转换为类型的对象 A –就像代码中发生的那样。
另一方面,我强烈建议您定义 serialVersionUID 如果您直接使用序列化来存储和检索对象,那么您的类。
你可以得到 serialVersionUID 以下是两个等级中的一个:

  1. ObjectStreamClass.lookup(A.class).getSerialVersionUID()
  2. ObjectStreamClass.lookup(B.class).getSerialVersionUID()

相关问题