代理模式(Proxy)
其实每个模式名称就表明了该模式的作用,代理模式就是多一个代理类出来,替原对象进行一些操作。代理对象控制对原对象的引用。
根据上文的阐述,代理模式就比较容易的理解了,我们看下代码:
- 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();
- }
-
- }
输出:
before proxy!
the original method!
after proxy!
代理模式的应用场景:
如果已有的方法在使用的时候需要对原有的方法进行改进,此时有两种办法:
1、修改原有的方法来适应。这样违反了“对扩展开放,对修改关闭”的原则。
2、就是采用一个代理类调用原有的方法,且对产生的结果进行控制。这种方法就是代理模式。
使用代理模式,可以将功能划分的更加清晰,有助于后期维护!
与装饰器模式的区别:代理模式体现的是透明调用思想,代理类的构造方式是一个无参构造函数,而装饰器模式一般需要将被装饰对象作为参数来进行显示地构造,以体现装饰器的思想。
Proxy(代理)
作用:
(1)透明调用被代理对象,无须知道复杂实现细节
(2)增加被代理类的功能
JDK中体现:动态代理;RMI
类图: