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

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

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


代理模式:控制对对象的访问_第1张图片

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结合可以创建非常强大的分布式应用。


你可能感兴趣的:(设计模式,rmi,代理模式)