这期内容当中小编将会给大家带来有关深入浅析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
软考中级精品资料免费领
- 历年真题答案解析
- 备考技巧名师总结
- 高频考点精准押题
- 资料下载
- 历年真题
193.9 KB下载数265
191.63 KB下载数245
143.91 KB下载数1148
183.71 KB下载数642
644.84 KB下载数2756
相关文章
发现更多好内容猜你喜欢
AI推送时光机深入浅析java 中JDK的动态代理类
后端开发2023-05-31
深入浅析java 中的JDK与cglib动态代理
后端开发2023-05-31
深入浅析java 1.8 中动态代理的原理
后端开发2023-05-31
深度剖析java中JDK动态代理机制
后端开发2023-05-31
浅析Java中的动态代理
后端开发2024-04-02
Java深入分析动态代理
后端开发2024-04-02
深入浅析JDK中的PriorityQueue
后端开发2023-05-31
深入浅析Java中的Object类
后端开发2023-05-31
深入浅析Java中的 List类
后端开发2023-05-31
深入浅析Java中的Properties类
后端开发2023-05-31
深入浅析Java中的String类
后端开发2023-05-31
深入理解java动态代理的两种实现方式(JDK/Cglib)
后端开发2023-05-31
JDK中动态代理的示例分析
后端开发2023-06-15
深入浅析Java中的AtomicLongArray原子类
后端开发2023-05-31
深入浅析Java中IO流的 RandomAccessFile类
后端开发2023-05-31
深入理解Java动态代理与静态代理
后端开发2024-04-02
深入浅析Java中 JVM的原理
后端开发2023-05-31
Java静态代理和动态代理的深入讲解
后端开发2024-04-02
咦!没有更多了?去看看其它编程学习网 内容吧