java之动态代理设计模式
发布时间:2020-12-15 06:43:40 所属栏目:Java 来源:网络整理
导读:代理:专门完成代理请求的操作类,是所有动态代理类的父类, 通过此类为一个或多个接口动态地生成实现类 。 弄清动态代理的关键是清楚java的 反射 机制,在https://www.cnblogs.com/xiximayou/p/12073611.html中已作详细说明。 具体实例:通过动态代理为Test
代理:专门完成代理请求的操作类,是所有动态代理类的父类,通过此类为一个或多个接口动态地生成实现类。 弄清动态代理的关键是清楚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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |