设计模式---代理模式

2021-10-09  本文已影响0人  lingfighting

创建一个新的对象,将原对象作为新对象的属性。使用原对象的地方,自动转为使用新对象,同样的功能方法,新对象可选择增强原对象的功能,也可选择重新实现原对象的功能

为其他对象提供一种代理以控制对这个对象的访问。

public BAdapter implements/extends B {
    private A a;
    public BAdapter(A a) {
        this.a = a;
    }
    public void b() {  // 名称为外部的接口名称,内部转换为,实际的接口
        a.a();
    }
}

对于外部调用者来说只关心调用操作是否被执行,而不会关心本次调用是被直接执行的还是被代理者间接执行的。所以,aop中,获取进行了aop功能增强的类,是通过接口获取(不能通过具体类名获取,ioc容器里面没有原来实现类的bean,只有代理类的bean),Spring自动转换为调用代理类

public AProxy implements/extends A {
    private A a;
    public AProxy(A a) {
        this.a = a;
    }
    public void a() {  // 只做功能增强,接口名称和主要功能不变
        this.a.a();
    }
}

这里最重要的就是:代理类持有被代理类的一个实例,无论代理类是继承还是接口实现

image.png
image.png

Decorator模式让调用者自己创建核心类,然后组合各种功能。Proxy模式决不能让调用者自己创建再组合,否则就失去了代理的功能。Proxy模式让调用者认为获取到的是核心类接口,但实际上是代理类

问题

class UserService {
  @AutoWired
  OrderService orderService;

  public void test() {
    log.info("哈哈哈哈哈");
    log.info("orderService: {}", orderService);
  };
}

是的。原因是代理对象是一个新的对象,和原来的被代理的UserService不是同一个对象,这个代理对象没有经过依赖注入,所以orderService属性是null

不是。代理对象持有target的是一个spring的bean,是通过依赖注入的bean。所以说代理模式,最重要的是:代理类持有被代理类的一个实例,无论代理类是继承还是接口实现

class UserServiceProxy extends  UserService {
  
  UserService target;

  public void test() {
    // aop增强逻辑:从切点缓存中获取
    target.test();
  };
}
上一篇 下一篇

猜你喜欢

热点阅读