代理:专门完成代理请求的操作类,是所有动态代理类的父类,通过此类为一个或多个接口动态地生成实现类。
弄清动态代理的关键是清楚java的反射机制,在https://www.cnblogs.com/xiximayou/p/12073611.html中已作详细说明。
具体实例:通过动态代理为TestProxy接口生成相应的实现类。
TestProxy.java
package Prox; public interface TestProxy { void test1(); test2(); }
TestProxyImpl.java
class TestProxyImpl implements TestProxy { @Override test1() { // TODO Auto-generated method stub System.out.println("执行test1"); } @Override test2() { TODO Auto-generated method stub System.out.println("执行test2"); } }
ProxyDemo.java
import java.lang.reflect.InvocationHandler; java.lang.reflect.Method; 这是动态代理类 class ProxyDemo InvocationHandler{ 被代理的对象 Object obj; public ProxyDemo(Object obj) { this.obj = obj; } @Override public Object invoke(Object proxy,Method method,Object[] args) throws Throwable { TODO Auto-generated method stub 这里指定代理对象的执行方法 System.out.println(method.getName()+"方法开始执行"); Object result = method.invoke(this.obj,args); System.out.println(method.getName()+"方法结束执行"); return result; } }
Test.java
java.lang.reflect.Proxy; class Test { static main(String[] args) { TestProxy testProxy = new TestProxyImpl(); testProxy.test1(); testProxy.test2(); InvocationHandler handler = ProxyDemo(testProxy); 第一个参数是handler.getClass().getClassLoader()类加载器 第二个参数是被代理对象的接口 第三个参数是代理的对象 返回值就是被成功代理后的对象 TestProxy tp = (TestProxy) Proxy.newProxyInstance(handler.getClass().getClassLoader(),testProxy.getClass().getInterfaces(),handler); System.out.println("---------------"); tp.test1(); System.out.println("---------------"); tp.test2(); System.out.println("---------------"); } }
输出:
执行test1
执行test2
---------------
test1方法开始执行
执行test1
test1方法结束执行
---------------
test2方法开始执行
执行test2
test2方法结束执行
---------------