文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

深入浅析java 中JDK的动态代理类

2023-05-31 12:40

关注

这期内容当中小编将会给大家带来有关深入浅析java 中JDK的动态代理类,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

详解java JDK 动态代理类分析(java.lang.reflect.Proxy)

 public class ProxyStudy {      @SuppressWarnings("unchecked")   public static void main(String[] args) throws Exception {     // 动态代理类:通用指定类加载器,和接口产生一类     // getProxyClass()返回代理类的 java.lang.Class 对象,并向其提供类加载器和接口数组。     Class clazzProxy = Proxy.getProxyClass(Collection.class.getClassLoader(), Collection.class);     System.out.println("动态产生的类名为:" + clazzProxy.getName());     System.out.println("----------获取动态产生的类的构造方法---------");     Constructor[] constructors = clazzProxy.getConstructors();     int i = 1;     for (Constructor constructor : constructors) {       System.out.println("第" + (i++) + "个构造方法名:" + constructor.getName());       Class[] parameterClazz = constructor.getParameterTypes();       System.out.println("第" + (i++) + "个构造方法参数:" + Arrays.asList(parameterClazz));     }     System.out.println("----------获取动态产生的类的普通方法---------");     Method[] methods = clazzProxy.getDeclaredMethods();     for (int j = 0; j < methods.length; j++) {       Method method = methods[j];       System.out.println("第" + (j + 1) + "个普通方法名:" + method.getName());       Class[] parameterClazz = method.getParameterTypes();       System.out.println("第" + (j + 1) + "个普通方法参数:" + Arrays.asList(parameterClazz));     }     System.out.println("---------获取动态代理对象的构造方法---------");     // 动态代理产生的对象的构造方法需要一个实现java.lang.reflect.InvocationHandler接口的对象,故不能通过     // clazzProxy.newInstance();产生一个对象,可以根据构造方法产生一个对象     // InvocationHandler 是代理实例的调用处理程序 实现的接口。     Constructor constructor = clazzProxy.getConstructor(InvocationHandler.class);      // 代理产生的对象     Collection proxyBuildCollection = (Collection) constructor         .newInstance(new InvocationHandler() {           // 为什么这里选择ArrayList作为目标对象?           // 因为这里的constructor是clazzProxy这个动态类的构造方法,clazzProxy是通过Proxy.getProxyClass()方法产生的,           // 该方法有两个参数,一个是指定类加载器,一个是指定代理要实现的接口,这个接口我上面指定了Collection           // 而ArrayList实现了Collection接口,固可以为该动态类的目标对象           ArrayList target = new ArrayList();// 动态类的目标对象            public Object invoke(Object proxy, Method method,               Object[] args) throws Throwable {             System.out.println("执行目标" + method.getName() + "方法之前:"                 + System.currentTimeMillis());             Object result = method.invoke(target, args);// 其实代理对象的方法调用还是目标对象的方法             System.out.println("执行目标" + method.getName() + "方法之后:"                 + System.currentTimeMillis());             return result;           }          });     proxyBuildCollection.clear();     proxyBuildCollection.add("abc");     proxyBuildCollection.add("dbc");     System.out.println(proxyBuildCollection.size());     System.out.println(proxyBuildCollection.getClass().getName());               System.out.println("-------------------下面的写法更简便--------------------");          // proxyBuildColl是对ArrayList进行代理     Collection proxyBuildCollection2 = (Collection) Proxy.newProxyInstance(         Collection.class.getClassLoader(),// 指定类加载器         new Class[] { Collection.class },// 指定目标对象实现的接口         // 指定handler         new InvocationHandler() {           ArrayList target = new ArrayList();            public Object invoke(Object proxy, Method method,               Object[] args) throws Throwable {             System.out.println(method.getName() + "执行之前...");             if (null != args) {               System.out.println("方法的参数:" + Arrays.asList(args));             } else {               System.out.println("方法的参数:" + null);             }             Object result = method.invoke(target, args);             System.out.println(method.getName() + "执行之后...");             return result;           }         });     proxyBuildCollection2.add("abc");     proxyBuildCollection2.size();     proxyBuildCollection2.clear();     proxyBuildCollection2.getClass().getName();          System.out.println("-------------------对JDK动态代理的重构--------------------");     Set proxySet = (Set) buildProxy(new HashSet(), new MyAdvice());     proxySet.add("abc");     proxySet.size();   }      public static Object buildProxy(final Object target,final AdviceInter advice) {     Object proxyObject = Proxy.newProxyInstance(         target.getClass().getClassLoader(),// 指定类加载器         target.getClass().getInterfaces(), // 指定目标对象实现的接口         // handler         new InvocationHandler() {                      public Object invoke(Object proxy, Method method,               Object[] args) throws Throwable {             advice.beforeMethod(target, method, args);             Object result = method.invoke(target, args);             advice.afterMethod(target, method, args);             return result;           }         });     return proxyObject;   }    }  

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 资料下载
  • 历年真题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯