代理模式

23种创新模式总署
父文链接

代理模式与装饰者模式非常相似,容易使人无法区别

装饰器模式关注于在一个对象上动态的添加方法,然而代理模式关注于控制对对象的访问。

用代理模式,代理类(proxy class)可以对它的客户隐藏一个对象的具体信息。因此,当使用代理模式的时候,我们常常在一个代理类中创建一个对象的实例。并且,当我们使用装饰器模式的时候,我们通常的做法是将原始对象作为一个参数传给装饰者的构造器。

  • 使用代理模式,代理和真实对象之间的的关系通常在编译时就已经确定了.
  • 装饰者能够在运行时递归地被构造。

代码:

public interface Sourceable {  
    public void method();  
}
public class Source implements Sourceable {  
  
    @Override  
    public void method() {  
        System.out.println("the original method!");  
    }  
}
public class Proxy implements Sourceable {  
  
    private Source source;  
    public Proxy(){  
        super();  
        /**
           *区别就在下面这句,是创建的,非作为参数传进来的
        */
        this.source = new Source();  
    }  
    @Override  
    public void method() {  
        before();  
        source.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) {  
        Sourceable source = new Proxy();  //区别(代理,装饰)
        source.method();  
    }  
  
}

代理模式的应用场景:

如果已有的方法在使用的时候需要对原有的方法进行改进,此时有两种办法:

  • 修改原有的方法来适应。这样违反了“对扩展开放,对修改关闭”的原则。
  • 就是采用一个代理类调用原有的方法,且对产生的结果进行控制。这种方法就是代理模式。
    使用代理模式,可以将功能划分的更加清晰,有助于后期维护!

你可能感兴趣的:(代理模式)