代理:专门完成代理请求的操作类,是所有动态代理类的父类,通过此类为一个或多个接口动态地生成实现类。
弄清动态代理的关键是清楚java的反射机制,
具体实例:通过动态代理为TestProxy接口生成相应的实现类。
TestProxy.java
package Prox; public interface TestProxy { public void test1(); public void test2(); }
TestProxyImpl.java
package Prox; public class TestProxyImpl implements TestProxy { @Override public void test1() { // TODO Auto-generated method stub System.out.println("执行test1"); } @Override public void test2() { // TODO Auto-generated method stub System.out.println("执行test2"); } }
ProxyDemo.java
package Prox; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; //这是动态代理类 public class ProxyDemo implements 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
package Prox; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Proxy; public class Test { public static void main(String[] args) { TestProxy testProxy = new TestProxyImpl(); testProxy.test1(); testProxy.test2(); InvocationHandler handler = new 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方法结束执行
---------------