记一次RMI的调用数据失误

这两天在测试一个Spring RMI接口的时候,出现了个奇怪的问题。Server端返回的数据,到了客户端出现了属性丢失的情况。
类继承体系 465508-20180911163125693-2018961933.png

。客户端里面定义在ClassA中的属性全部为null。

分析问题:

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 接口。更新后的类图:465508-20180911163147016-1900149837.png

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'}

解读

序列化的使用场景:

  1. 当你想把的内存中的对象状态保存到一个文件中或者数据库中时候;
  2. 当你想用套接字在网络上传送对象的时候;
  3. 当你想通过RMI传输对象的时候;

小结:

序列化的范围是 Serializable 接口的子类,不包含该子类的不包含。

转载于:https://www.cnblogs.com/jason0529/p/9628585.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值