业务场景
(1)懒加载:hibernate、mybatis,都可以实现懒加载,其实也是基于动态代理思想实现的,对刚查询出来的对象做一个代理。然后去调用getX()方法的时候,再实际执行sql查询出来关联的数据。
通过hibernate / mybatis,查询出来这个classroom的时候,是没有级联将students数据从数据库里查出来的。接下来,如果你要从classroom中获取students集合来使用的时候,你会去调用getStudents()。
懒加载的原理,其实就是基于代理模式去做的,刚从数据库中查询出来的是classroom的一个代理对象
(2)远程调用:比如 thrift 等 rpc 调用包,都是在本地做一个远程服务的本地代理接口,然后对本地代理接口来调用,然后代理对象发送网络请求调用远程服务的接口
系统要调用另外的一个系统的接口,要走网络请求,远程调用,http接口;rpc,系统在本地就是调用一个代理类的接口,代理类在接口的代理实现中,是会发送网络请求跟远程的系统通信,调用对方的接口
spring cloud,dubbo,分布式系统的架构,分布式系统之间互相的调用,就是大量的用了代理模式,代理接口,代理了远程系统的接口
public class ProxyPatternDemo {
public static void main(String[] args) {
Subject subject = new ConcreteSubject();
Subject proxy = new Proxy(subject);
proxy.request();
}
public interface Subject {
void request();
}
public static class ConcreteSubject implements Subject {
@Override
public void request() {
System.out.println("执行请求");
}
}
public static class Proxy implements Subject {
private Subject subject;
public Proxy(Subject subject) {
this.subject = subject;
}
@Override
public void request() {
System.out.println("执行额外的条件判断,拷贝是否要调用subject的request()方法");
boolean invoke = true;
if (invoke) {
subject.request();
}
}
}
}