代理模式的意图是为其他对象提供一种代理以控制对这个对象的访问。首先,作为代理,代理对象必须与被代理对象有相同的接口,这是非常重要的。换句话说,用户不能因为使用或者不使用代理而改变,其次,需要通过代理控制对象的访问。这时对于需要代理的客户,被代理对象应该是不透明的;否则谈不上控制。
(1)Proxy:保存一个引用使得代理可以访问实体。若RealSubject和subject的接口相同,Proxy会引用Subject。
(2)Subject:声明了真实主题和代理主题的共同接口,这样一来在任何使用真实主题的地方都可以使用代理主题。
(3)RealSubject:定义了Proxy代表的实体。
代理对象和被代理对象都遵循一致的接口。
代理模式的应用场景:
如果已有的方法在使用的时候需要对原有的方法进行改进,此时有两种办法:
1、修改原有的方法来适应。这样违反了“对扩展开放,对修改关闭”的原则。
2、就是采用一个代理类调用原有的方法,且对产生的结果进行控制。
(1)Proxy:保存一个引用使得代理可以访问实体。若RealSubject和subject的接口相同,Proxy会引用Subject。
(2)Subject:声明了真实主题和代理主题的共同接口,这样一来在任何使用真实主题的地方都可以使用代理主题。
(3)RealSubject:定义了Proxy代表的实体。
代理对象和被代理对象都遵循一致的接口。
public interface Subject{
public void method();
}
public class RealSubject implements Subject{
@Override
public void method() {
System.out.println("the original method!");
}
}
public class Proxy implements Subject {
private Subject subject;
public Proxy(){
super();
this.subject = new Subject();
}
@Override
public void method() {
before();
subject.method();
atfer();
}
private void atfer() {
System.out.println("after proxy!");
}
private void before() {
System.out.println("before proxy!");
}
}
测试类:public class ProxyTest {
public static void main(String[] args) {
Subject subject = new Proxy();
subject.method();
}
}
代理模式的应用场景:
如果已有的方法在使用的时候需要对原有的方法进行改进,此时有两种办法:
1、修改原有的方法来适应。这样违反了“对扩展开放,对修改关闭”的原则。
2、就是采用一个代理类调用原有的方法,且对产生的结果进行控制。
这种方法就是代理模式。使用代理模式,可以将功能划分的更加清晰,有助于后期维护!
关于java的动态代理与cglib可参见 http://blog.youkuaiyun.com/zero__007/article/details/44280529