- 1、本文档共6页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
RMI参数传递试验
概述
Java在调用本地函数时,简单类型是按值传递,同时对象是按引用传递的,即类似于C中的指针传递;而在RMI程序中调用一个远程方法时,由于客户机于服务器各自拥有不同的内存空间,所以传递类引用时必须将类成员的信息发送到远程机器,即对象必须先被序列化,之后再送到远程机器。
下面用两种方法,通过程序验证RMI对象是按序列化值传递的。
通过外层类方法修改类成员变量验证
根据Java参数传递的特点,可通过对比类成员变量是否被外层类方法修改成功验证。所以设计以下方法验证,首先将A对象赋值到类B的成员变量中,然后通过类B的方法修改A对象的引用,并打印显示修改是否成功,以验证是否传递引用。
此处通过设计以下程序实现验证:
分别在本地与服务器建立LocalAuthority、AuthorityImpl两个外层类,把Account对象赋值到外层类的account域中,并调用changePassword修改Account对象的password域,最后打印Account的password查看是否修改成功。
实验过程
启动RMI Registry
启动RMI服务端
启动客户端(本地模式)
运行程序,根据输出结果可以看到,该程序首先模拟登陆帐户Account( admin ,123456),然后调用LocalAuthority.changePassword将帐户密码修改为newpassword,最后输出密码,可以看到密码修改成功,证实本地对象传递是按照引用传递的。
启动客户端(远程模式)
客户端输出
服务器端输出
运行程序,根据输出结果可以看到,程序首先模拟登陆帐户Account( admin ,123456),然后调用AuthorityImpl.changePassword将帐户密码修改为newpassword,最后输出密码,可以看到密码修改失败,依然是原密码123456,证实RMI对象传递是按Copy传递的。
试验结果
本地对象传递是按照引用传递的而RMI对象传递是按Copy传递的。
通过静态变量不参与序列化验证
首先根据Java序列化的特性可知,类静态成员不会被序列化,而对象成员会被序列化,所以可以通过设计以下程序实现验证:
Client程序向Server请求一个Account对象,Server为Account对象预先设定好相应的初值,主要包括一个静态变量和一个普通成员变量:auto_id_static、autoId;Client程序每次请求时Server为这两个变量自增值,Client获取对象之后打印对比变量的值。
实验过程
启动RMI Registry
启动RMI服务端
启动客户端
服务器端输出
客户端输出
根据程序输出结果可以看到,account对象的autoId和userId域更新,而静态变量auto_id_static始终为0
试验结果
RMI是通过序列化传递对象的
总结
Java在调用本地函数时,简单类型是按值传递,同时对象是按引用传递的;而在RMI程序中调用远程方法时,由于客户机于服务器各自拥有不同的内存空间,所以传递对象时必须将对象序列化之后再送到远程机器。
附件
程序一
Account.java
AuthorityImpl.java
AuthorityServer.java
ClientC.java
IAuthority.java
LocalAuthority.java
程序二
Account.java
AuthorityImpl.java
AuthorityProxyImpl.java
AuthorityServer.java
ClientA.java
ClientB.java
ClientC.java
IAuthority.java
IAuthorityProxy.java
LocalAuthority.java
文档评论(0)