快速业务通道

用RMI实现基于Java的分布式计算 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-20

用RMI实现基于Java的分布式计算

时间:2011-01-22

Java 2 Enterprise Edition(J2EE)远程方法调用(Remote Method Invocation,RMI)框架允许你创建透明的、分布式的服务和应用程序。基于RMI的应用程序由Java对象构成,这些对象相互调用,同时忽略对方的位置。换言之,一个Java对象可调用另一个虚拟机上的某个Java对象的方法,整个过程和调用同一个虚拟机上的某个Java对象的方法无异。驻留在不同虚拟机上的对象为了相互获得引用,可以使用RMI的查找服务,或者将对象引用作为方法调用的一个参数或者返回值来接收。参数和返回值借助Java的对象序列化机制由RMI来进行封送。

远程对象和接口

Java提供了一个完全限定名称为java.rmi.Remote的接口。任何对象要想参与和另一个Java对象的远程会话,就必须直接或间接地实现该接口。尤其要注意的是,任何由java.rmi.Remote接口来标识的对象都暗示着它的方法可从其他任何虚拟机进行调用。实现了java.rmi.Remote接口的对象通常称为“远程对象”,必须采用以下方式来声明它的方法:

每个支持远程调用的方法都必须在其throws子句中声明java.rmi.RemoteException。

对于一个可远程调用的方法,它的每个非基本(nonprimitive)参数或者返回值都必须直接或间接地声明为实现了java.io.Serializable接口。

除了实现java.rmi.Remote接口和正确声明任何远程方法之外,远程对象必须提供一个无参数的构造函数,它能引发一个java.rmi.RemoteException异常。这就保证了对象可基于一种序列化状态来远程构造。

远程对象必须导出,以接收传入的远程方法调用。为此,你通常需要扩展java.rmi.server.UnicastRemoteObject或者java.rmi.activation.Activatable。通过对其中任何一个类进行扩展,远程对象就可在创建时自动导出。

以下接口定义展示了java.rmi.Remote接口最典型的用法:

import java.rmi.Remote; import java.rmi.RemoteException; public interface TimeKeeper extends Remote { public String currentDate() throws RemoteException; public String currentTime() throws RemoteException; }

由于String类声明为实现了java.io.Serializable接口,所以String是远程方法的有效返回类型。

以下代码展示了如何实现TimeKeeper接口,以便定义一个有效的远程对象:

import java.rmi.RemoteException; import java.util.Calendar; import java.util.GregorianCalendar; public class TimeKeeperImpl implements TimeKeeper { public TimeKeeperImpl() throws RemoteException { } public String currentDate() throws RemoteException { Calendar cal = new GregorianCalendar(); String retVal = (cal.get(Calendar.MONTH) + "/" + cal.get(Calendar.DAY_OF_MONTH) + "/" + cal.get(Calendar.YEAR)); return retVal; } public String currentTime() throws RemoteException { Calendar cal = new GregorianCalendar(); String retVal = (cal.get(Calendar.HOUR_OF_DAY) + ":" + cal.get(Calendar.MINUTE) + ":" + cal.get(Calendar.SECOND)); return retVal; } }

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号