代理模式:控制对对象的访问

跟《HeadFirst设计模式》中一样,我也不准备讲普通的代理模式,而要专门介绍一下Java的远程代理,也就是RMI

远程代理的类图很简单,只有一个接口和一个实现类:


DuckServer是一个继承了Remote的接口,其中有一个等待实现的quack方法。DuckDuckServer的实现类,继承自UnicastRemoteObject

Duck中有一个程序主方法main,这样Duck是一个可执行的Java类。main方法中注册了DuckServer远程服务:

publicstatic void main(String[] args) {

try{

DuckServerduckServer = new Duck();

Naming.rebind("DuckServer",duckServer);

}catch (RemoteException e) {

//TODO Auto-generated catch block

e.printStackTrace();

}catch (MalformedURLException e) {

//TODO Auto-generated catch block

e.printStackTrace();

}

}

以下的代码用来调用远程服务:

publicvoid testQuack() {

try{

DuckServerduckServer = (DuckServer)Naming.lookup("rmi://127.0.0.1/DuckServer");

Strings = duckServer.quack();



System.out.println(s);

}catch (MalformedURLException e) {

//TODO Auto-generated catch block

e.printStackTrace();

}catch (RemoteException e) {

//TODO Auto-generated catch block

e.printStackTrace();

}catch (NotBoundException e) {

//TODO Auto-generated catch block

e.printStackTrace();

}

}

当然,在调用远程服务前需要先运行rmiregistry服务,并运行远程代理的服务端(在本例子中,即Duck类)。

顺便提一句,RMIHadoop结合可以创建非常强大的分布式应用。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值