代理模式
一、定义
代理模式给需要代理的对象提供了一个代理对象,并由代理对象来控制对原对象的引用,以此来扩展原对象的功能。
二、代理模式的目的
- 中介隔离
- 开闭原则,增加功能
- 实现解耦,从业务中代码中抽离功能相同的代码,降低代码的耦合度,便于后期的维护;
三、静态代理
静态代理:是由程序员创建或者由特定的工具生成源代码,编译时代理类xxx.class就已被创建;可以直接使用继承的方式实现,但是破环了面向对象的开闭原则,使用接口方式可提高程序的扩展性和灵活性,下面使用接口方式实现简单的静态代理
package proxy;
//接口
public interface BuyCar {
void buyCar();
}
package proxy;
//接口实现类
public class BuyCarImp implements BuyCar{
@Override
public void buyCar() {
System.out.println("买辆保时捷!");
}
}
package proxy;
//静态代理实现类
public class BuyCarImpProxy implements BuyCar {
private BuyCar buyCar;
public BuyCarImpProxy(BuyCar buyCar){
this.buyCar = buyCar;
}
@Override
public void buyCar() {
buyCar.buyCar();
System.out.println("挂牌,办理保险...");
}
}
package proxy;
//静态代理测试类
public class ProxyTest {
public static void main(String[] args) {
BuyCar buyCar = new BuyCarImpProxy(new BuyCarImp());
buyCar.buyCar();
}
}
运行结果:
买辆保时捷!
挂牌,办理保险...
四、动态代理
动态代理是在程序运行时通过反射机制来创建的代理对象;首先实现InvocationHandler接口,然后通过java API创建代理类,最后动态加载代理类,代理类实现接口,使用handler(Proxy.newProxyInstance)以及调用invoke方法
package proxy;
//动态代理处理类
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
public class BuyCarProxyHandle implements InvocationHandler {
private Object object;
public BuyCarProxyHandle(Object object) {
this.object = object;
}
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
Object result = method.invoke(object,args);
System.out.println("挂牌,办理保险...");
return result;
}
}
package proxy;
//动态代理测试类
import java.lang.reflect.Proxy;
public class BuyCarProxyHandleTest {
public static void main(String[] args) {
BuyCar buyCar = new BuyCarImp();
BuyCar buyCarProxy = (BuyCar) Proxy.newProxyInstance(BuyCar.class.getClassLoader(),
new Class[] {BuyCar.class},new BuyCarProxyHandle(buyCar));
buyCarProxy.buyCar();
}
}
运行结果:
买辆保时捷!
挂牌,办理保险...
运用:spring AOP就时通过动态代理来实现的,如:事务,日志管理…;登录校验(拦截器的使用)也动态代理的应用场景。
五、CGLIB代理
CGLIB(Code Generation Library)是一个开源项目!是一个强大的,高性能,高质量的Code生成类库,它可以在运行期扩展Java类与实现Java接口。(不了解,后续补充…)