- 作者:zhaozj
- 发表时间:2020-12-23 10:35
- 来源:未知
做过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接口。参考java.rmi.Remote,注意异常的抛出问题。
(2) 编写服务器类。用面向对象的观点来考虑这个问题。(3) 编写使用远程服务的客户机程序。用java.rmi.Naming中的lookup()方法获得对远
程对象的引用,依据需要调用该引用的远程方法,其调用方式和对本地对象方法的调
用相同。?4)编译和运行RMI分布式应用程序的步骤 (1) 使用javac编译远程接口类,远程接口实现类和客户机程序。按自己的业务逻辑写代码.。 (2) 使用rmic编译器生成实现类的stub和skeleton。 自动实现的啦,不用我们去管。.(3) 启动RMI注册服务程序rmiregistry。使用CORBA系统时能看到这个窗口.。 (4) 启动服务器端程序。 (5) 启动客户机程序。
说明:最好看看java.rmi的包来理解上面的概念;最好看看< >的附录的
讲解.