首先先解释一下什么是代理模式,代理模式的作用就是为其它对象提供一种代理用来控制对这个对象的访问。那么,代理模式会有哪些角色呢?代理模式涉及到的角色有:
1、抽象角色,声明真实对象和代理对象的共同接口/
2、代理角色,代理对象角色内部含有真是对象的引用,从而可以操作真实对象,同时代理对象提供与真是对象相同的接口以便在任意时刻都能代理真是对象。同时,代理对象可以在执行真实对象操作时,附加其它的操作,相当与对真是对象进行封装/
3、真实角色,代理角色所代表的真是对象,是我们最终要引用的对象。
下面举例实际场景应用:实现对Waiter中的service方法进行增强,直接看代码
声明接口Waiter
public interface Waiter {
public void service();
}
Waiter的实现类
public class Waitress implements Waiter {
public void service() {
// TODO Auto-generated method stub
System.out.println("服务中。。。");
}
}
然后是我把代理角色和测试类都写到一块了
public class ProxyDemo {
@Test
public void demo1(){
final Waiter waiter=new Waitress();
<span style="white-space:pre"> </span>//此处的三个参数分别是类加载器,代理对象实现的所有接口,处理类
Waiter waiter2=(Waiter)Proxy.newProxyInstance(waiter.getClass().getClassLoader(),
waiter.getClass().getInterfaces(), new MyInvocationHandler(waiter));
waiter2.service();
}
}
//每一个动态代理类都必须实现InvocationHandler这个接口
</span>class MyInvocationHandler implements InvocationHandler{
private Waiter waiter;
public MyInvocationHandler(Waiter waiter){
this.waiter=waiter;
}
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
//目的是增强service方法
if ("service".equals(method.getName())) {
//在代理真实对象前我们可以加一些自己的操作,
//我想增强service方法就在此处增强
System.out.println("餐厅服务员");
}
return method.invoke(waiter, args);
}
}
这样就简单通过动态代理实现了对service方法的增强,这种思想很巧妙啊!