java RMI 源码总结(个人理解)

明天早上详细写下两个过程:

1、初始化过程(服务器)

2、客户端调用过程(包括客户端流程、调用服务端流程、返回客户端流程)

50b2aecb8149c0045d293fe21525d9689b5.jpg

  • 当客户端通过RMI注册表找到一个远程接口的时候,所得到的其实是远程接口的一个动态代理对象。
  • 当客户端调用其中的方法的时候,方法的参数对象会在序列化之后,传输到服务器端。
  • 服务器端接收到之后,进行反序列化得到参数对象。
  • 并使用这些参数对象,在服务器端调用实际的方法。
  • 调用的返回值Java对象经过序列化之后,再发送回客户端。
  • 客户端再经过反序列化之后得到Java对象,返回给调用者。
  • 这中间的序列化过程对于使用者来说是透明的,由动态代理对象自动完成

除了序列化之外,RMI还使用了动态类加载技术

  • 当需要进行反序列化的时候,如果该对象的类定义在当前JVM中没有找到,RMI会尝试从远端下载所需的类文件定义
  • 可以在RMI程序启动的时候,通过JVM参数java.rmi.server.codebase来指定动态下载Java类文件的URL。 

具体执行笔记参看代码注释

转载于:https://my.oschina.net/u/3847203/blog/2877353

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值