- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第3章 RMI及RMI-IIOP
第三章 软件互操作 第三章 软件互操作 第三章 软件互操作 3.1 基于TCP/IP的通信过程 基于TCP/IP的通信过程 3.1 基于TCP/IP的通信过程 套接字: 缺点:通信过程繁琐。 不能根据请求内容,区分处理,调用不同的处理过程。 第三章 软件互操作 第三章 软件互操作 3.2 RMI原理及应用 3.2.1 RMI基础 远程对象:由接口和实现两个部分,由远程接口暴露远程对象的方法。 在RMI中不能直接对对象实现实施远程调用,只能对对象的接口操作。 远程接口必须扩展java.rmi.Remote,接口中包含远程对象公开的每个方法的拷贝。 (2)远程方法参数传递惯例 参数传递惯例 调用方法时,传递的参数为值传递。当通过RMI调用方法时,所有给远程方法的参数是按值传递的。 这意味着,当调用目标方法时,所有的参数从一个机器拷贝到另一个机器。 为什么不能是传引用呢?一个机器的内存地址结构,不会与另一个机器的完全相同。目标机器中相应地址,不会正好存在这个被引用的对象。 (3)对象序列化 如果传递的参数是基本类型(int,long,float等)不用序列化; 如果是一个对象,它必须实现java.lang.Serializable接口,即为对象序列化。 所有对象被序列化为bit-blob,通过网络发送,然后在目标机器上解序列化。 2. 指代作用 指代作用1:RMI利用指代完成客户与服务器的关联. 指代的理解:提供高层互操作的程序模块, 但不包含任何 业务逻辑. RMI程序编写步骤 1、 编写并且编译接口的Java代码 2、 编写并且编译接口实现的Java代码。 3、 编写客户端程序 4、 编写绑定服务的程序代码。 5、运行客户端程序 3.2.4 远程方法调用实例---生成主键(RMI-IIOP) 该例回答以下三个问题: ●远程对象组成;(代码) ●远程对象的绑定操作。(图示+代码) ●客户查找并调用远程对象。(图示+代码) 3.2.4 远程方法调用实例---生成主键 该例回答以下三个问题: ●远程对象组成;(代码) ●远程对象的绑定操作。(图示+代码) ●客户查找并调用远程对象。(图示+代码) 3.2 RMI原理及应用 3.2.4 远程方法调用实例---生成主键 构建远程对象 远程对象组成: 接口:用于暴露对象的信息。 实现:具体实现功能的程序代码。 3.2 RMI原理及应用 3.2.4 远程方法调用实例---生成主键 ◆远程接口 ---- IPKGenerator.java import java.rmi.Remote; import java.rmi.RemoteException; public interface IPKGenerator extends Remote { //RemoteException: 当网络相关问题出现时,将被抛出. public long generate() throws RemoteException; } 3.2 RMI原理及应用 3.2.4 远程方法调用实例---生成主键 ◆远程对象实现 --- PKGenerator.java import java.rmi.RemoteException; public class PKGenerator implements IPKGenerator { public PKGenerator() throws Exception, RemoteException { super(); } public synchronized long generate() throws RemoteException { return i++; } private i = 0; } 3.2 RMI原理及应用 3.2.4 远程方法调用实例---生成主键 该例回答以下三个问题: ●远程对象组成;(代码) ●远程对象的绑定操作。(图示+代码) ●客户查找并调用远程对象。(图示+代码) 3.2 RMI原理及应用 3.2.4 远程方法调用实例---生成主键 2. 构建实例的支持技
原创力文档


文档评论(0)