标签:imp 基础 文件 src 例子 load interface tin str
在介绍动态代理之前首先简单捎带下静态代理(自己的理解)
所谓静态代理是实际调用者通过一个代理对象调用目标对象的方法,代理对象与目标对象必须具备相同的方法名,
所以代理对象和目标对象必须实现同一个接口。静态代理的缺点是:开发者必须自己手动实现 代理类
所谓动态代理,是 当 .java源码通过类加载器变成字节码文件时,在内存中动态生成目标对象的代理对象。
开发人员不需要自己定义代理类。(下面举个例子,给出实现动态代理的代码)
//1.目标对象和代理对象实现的接口 package com.itheima.proxy; public interface TargetInterface { public void method1(); public String method2(); }
//2.目标对象 package com.itheima.proxy; public class Target implements TargetInterface{ @Override public void method1() { System.out.println("method1 running..."); } @Override public String method2() { System.out.println("method2 running..."); return "method2"; } }
//3.动态生成代理对象 package com.itheima.proxy; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy; import org.junit.Test; public class ProxyTest { @Test public void test1() { // 获得动态的代理对象----在运行时 在内存中动态的为Target创建一个虚拟的代理对象 // objProxy是代理对象 根据参数确定到底是谁的代理对象 TargetInterface objProxy = (TargetInterface) Proxy.newProxyInstance(Target.class.getClassLoader(), // 与目标对象相同的类加载器 new Class[] { TargetInterface.class }, new InvocationHandler() { // invoke 代表的是执行代理对象的方法 @Override // method:代表目标对象的方法字节码对象 // args:代表目标对象的响应的方法的参数 public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println("目标方法前的逻辑"); // 通过反射执行目标对象的方法 Object invoke = method.invoke(new Target(), args); System.out.println("目标方法后的逻辑"); return invoke; } }); objProxy.method1(); String method2 = objProxy.method2(); System.out.println(method2); } }
标签:imp 基础 文件 src 例子 load interface tin str
原文地址:https://www.cnblogs.com/houchen/p/10675488.html