RMI入门

做过UNIX下编程的朋友应该都听说过RPC的概念了,RPC的全称是Remote Procedure
  Call;如果和RMI的全称(Remote Method Invocation)比较,聪明的你应该知道了他们的
  区别了:RPC是基于过程的,RMI是面向对象的.实际上,RMI是RPC的JAVA版本,因此,Java
  RMI具有Java的"Write Once,Run Anywhere"的优点,是分布式应用系统的百分之百纯
  Java解决方案。
  1)为什么序列化
  既然是分布式应用系统,就涉及多JRE的问题.在A JRE中的对象,它的内存地址是
  0xabcdef,该地址存放的值,和B JRE中的该地址放的值是不同的,所以,RMI不支持序列
  化是不行的.我们在RMI的包中可以看到支持 Serializable(可序列化)的接口.
  2)RMI系统运行机制
  RMI应用程序通常包括两个独立的程序:服务器程序和客户机程序,这和一般的C/S开发
  模式没有什么区别.RMI也是基于ORB标准的,包括stub和skeleton.调用stub的方法时将
  执行下列操作:(1) 初始化与包含远程对象的远程虚拟机的连接;(2) 对远程虚拟机
  的参数进行编组(写入并传输);(3) 等待方法调用结果;(4) 解编(读取)返回值
  或返回的异常;(5) 将值返回给调用程序。skeleton调用过程就不用说了吧.stub和
  skeleton不用自己写,它由rmic编译器生成。
  3)编写Java RMI分布式应用程序的步骤
  (1) 将远程类的功能定义为Java接口。
  (2) 编写服务器类。
  (3) 编写使用远程服务的客户机程序。用java.rmi.Naming中的lookup()方法获得对远
  程对象的引用,依据需要调用该引用的远程方法,其调用方式和对本地对象方法的调
  用相同。
  4)编译和运行RMI分布式应用程序的步骤
  (1) 使用javac编译远程接口类,远程接口实现类和客户机程序。
  (2) 使用rmic编译器生成实现类的stub和skeleton。
  (3) 启动RMI注册服务程序rmiregistry。
  (4) 启动服务器端程序。
  (5) 启动客户机程序。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值