手把手教学:动态代理模式
1.代理对象,不需要实现接口,但是目标对象要实现接口,否则不能用动态代理
2.代理对象的生成是利用JDK的API,动态的在内存中构建代理对象
3.动态代理也叫做:JDK代理,接口代理
JDK中生成代理对象的API
1.代理类所在包:java.lang.reflect.Proxy
2.JDK实现代理只需要是用newProxyInstance方法,但是改方法需要接收三个参数,完整的写法是:
public static Object newProxyInstance( ClassLoader loader,
Class<?>[] interfaces,
InvocationHandler h)
解析:
1.ClassLoader loader:指定当前目标对象使用的类加载器,获取加载的方法固定。
2.Class<?>[] interfaces:目标对象实现的接口类型,使用泛型方法确认类型。
3.InvocationHandler h:事件处理,执行目标对象的方法时,会触发时间处理器方法
会把当前执行的目标对象方法作为参数传入。
上解析图:
不使用动态代理实现吃饭流程:
使用动态代理:
本质上和静态代理模式是一样的,但是代码实现不同。
上代码:(最终代码片和截图会放在本文最末)
先创建一个接口类,定义一个吃的接口
然后定义一个实现类,实现吃的接口,用来实现吃的接口,顺便打印:小红吃饭ing----
然后是代理类:
代理类太长了就直接看代码片吧,讲解的时候用截图就行了
-----------------------------------------无情的分割线--------------------------------------------------------------------
//代理类
public class ProxyFactory {
//维护一个目标对象,Object
private Object target;
//构造器,对target进行初始化
public ProxyFactory(Object target){
this.target = target;
}
//给目标对象生成一个代理对象
public Object getProxyInstance(){
/**
* 说明:
* public static Object newProxyInstance(ClassLoader loader,
* Class<?>[] interfaces,
* InvocationHandler h)
* 1.ClassLoader loader:指定当前目标对象使用的类加载器,获取加载器的方法固定
* 2.Class<?>[] interfaces:目标对象实现的接口类型,使用泛型方法确认类型
* 3.InvocationHandler h:事件处理,执行目标对象的方法时,会触发事件处理器方法
* 会把当前执行的目标对象方法作为参数传入
*/
return Proxy.newProxyInstance(target.getClass().getClassLoader(),
target.getClass().getInterfaces(),
new InvocationHandler