这两天在测试一个Spring RMI接口的时候,出现了个奇怪的问题。Server端返回的数据,到了客户端出现了属性丢失的状况。
类继承体系java
。客户端里面定义在ClassA中的属性所有为null。shell
RMI过程当中的数据有一个序列化和反序列化的过程,分析多是因为序列化和反序列化的缘由致使数据丢失。数据库
public static void main(String[] args) throws IOException, ClassNotFoundException { ClassB b = new ClassB(); b.setName("abc"); b.setId(1L); logger.info(b.toString()); FileOutputStream fs = new FileOutputStream("foo.ser"); ObjectOutputStream os = new ObjectOutputStream(fs); os.writeObject(b); ObjectInputStream is = new ObjectInputStream(new FileInputStream("foo.ser")); ClassB b2 = (ClassB) is.readObject(); logger.info(b2.toString()); }
反序列化的数据丢失了父类ClassA中的属性。网络
ClassA也实现 Serializable 接口。更新后的类图:测试
16:24:37.769 [main] INFO ser.Main - ClassB{id='1'name='abc'} 16:24:37.879 [main] INFO ser.Main - ClassB{id='1'name='abc'}
序列化的使用场景:3d
序列化的范围是 Serializable 接口的子类,不包含该子类的不包含。code