不定期整理硬盘内源代码、笔记、总结等,同时发上来分享一下。今天再发一篇关于Java动态代理的总结(貌似ItEye一天最多发5篇Blog,再多只能放草稿箱了?)
-----------------------------------------------------------
Java动态代理详解
说到动态代理,顾名思义就是动态的代理(真是废话)。
关于代理:想必大家都并不陌生,GOF的23种设计模式之一(结构型模式)。这里暂不多做介绍,有兴趣的可以关注我关于设计模式的文章。
什么是动态代理:
说起动态,其实不如先说什么是静态。所谓静态代理,个人理解为自己手写的代理类,或者用工具生成的代理类,或者别人帮你写的代理类(没说一样...)。总之,就是程序运行前就已经存在的编译好的代理类。
相反,如果代理类程序运行前并不存在,需要在程序运行时动态生成(无需手工编写代理类源码),那就是今天要说的动态代理了。
如何生成的:根据Java的反射机制动态生成。
不多说了,上程序。
目标接口TargetInterface:
public interface TargetInterface { public int targetMethodA(int number); public int targetMethodB(int number); }
很简单,一个普通的接口,里面有若干方法(此处写2个示范一下)
实现该接口的委托类ConcreteClass:
public class ConcreteClass implements TargetInterface{ public int targetMethodA(int number) { System.out.println("开始调用目标类的方法targetMethodA..."); System.out.println("操作-打印数字:"+number); System.out.println("结束调用目标类的方法targetMethodA..."); return number; } public int targetMethodB(int number){ System.out.println("开始调用目标类的方法targetMethodB..."); System.out.println("操作-打印数字:"+number); System.out.println("结束调用目标类的方法targetMethodB..."); return number; } }
很简单,一个普通的类,实现了目标接口。
代理处理器类ProxyHandler:
public class ProxyHandler implements InvocationHandler{ private Object concreteClass; public ProxyHandler(Object concreteClass){ this.concreteClass=concreteClass; } public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println("proxy:"+proxy.getClass().getName()); System.out.println("method:"+method.getName()); System.out.println("args:"+args[0].getClass().getName()); System.out.println("Before invoke method..."); Object object=method.invoke(concreteClass, args);//普通的Java反射代码,通过反射执行某个类的某方法 //System.out.println(((ConcreteClass)concreteClass).targetMethod(10)+(Integer)args[0]); System.out.println("After invoke method..."); return object; } }
该类实现了Java反射包中的InvocationHandler接口。代理实例调用方法时,将对方法调用指派到它的代理处理器程序的invoke方法中。invoke方法内部实现预处理,对委托类方法调用,事后处理等逻辑。
最后是入口程序:
public class DynamicProxyExample { public static void main(String[] args){ ConcreteClass c=new ConcreteClass();//元对象(被代理对象) InvocationHandler ih=new ProxyHandler(c);//代理实例的调用处理程序。 //创建一个实现业务接口的代理类,用于访问业务类(见代理模式)。 //返回一个指定接口的代理类实例,该接口可以将方法调用指派到指定的调用处理程序,如ProxyHandler。 TargetInterface targetInterface= (TargetInterface)Proxy.newProxyInstance(c.getClass().getClassLoader(),c.getClass().getInterfaces(),ih); //调用代理类方法,Java执行InvocationHandler接口的方法. int i=targetInterface.targetMethodA(5); System.out.println(i); System.out.println(); int j=targetInterface.targetMethodB(15); System.out.println(j); } }
首先创建委托类对象,将其以构造函数传入代理处理器,代理处理器ProxyHandler中会以Java反射方式调用该委托类对应的方法。然后使用Java反射机制中的Proxy.newProxyInstance方式创建一个代理类实例,创建该实例需要指定该实例的类加载器,需要实现的接口(即目标接口),以及处理代理实例接口调用的处理器。
最后,调用代理类目标接口方法时,会自动将其转发到代理处理器中的invoke方法内,invoke方法内部实现预处理,对委托类方法调用,事后处理等逻辑。
使用Java动态代理机制的好处:
1、减少编程的工作量:假如需要实现多种代理处理逻辑,只要写多个代理处理器就可以了,无需每种方式都写一个代理类。
2、系统扩展性和维护性增强,程序修改起来也方便多了(一般只要改代理处理器类就行了)。
使用Java动态代理机制的限制:
目前根据GOF的代理模式,代理类和委托类需要都实现同一个接口。也就是说只有实现了某个接口的类可以使用Java动态代理机制。但是,事实上使用中并不是遇到的所有类都会给你实现一个接口。因此,对于没有实现接口的类,目前无法使用该机制。有人说这不是废话吗,本来Proxy模式定义的就是委托类要实现接口的啊!但是没有实现接口的类,该如何实现动态代理呢?
当然不是没有办法,这也是我后面抽时间要继续整理和总结原先使用过的一件神器,相关Blog会不定期发上来。那就是大名鼎鼎的CGLib...
PS:CGLib中的动态代理已经新鲜出炉,欢迎访问:http://shensy.iteye.com/blog/1873155
相关推荐
更好的了解java动态代理的原理!
Java 动态代理详解(学习资料);Java 动态代理详解(学习资料);Java 动态代理详解(学习资料);Java 动态代理详解(学习资料);Java 动态代理详解(学习资料);
Java 动态代理详解(代理模式+静态代理+JDK动态代理+CGLIB动态代理)
简介Java编程的目标是实现现实不能完成的,优化现实能够完成的,是一种虚拟技术。生活中的方方面面都可以虚拟到代码中。代理模式所讲的就是现实生活中的这么一个概念:
Java动态代理机制详解[整理].pdf
详细介绍了开发java动态代理用到的相关类,和动态代理类的特点!最后以完整示例代码的形式,展现了java动态代理开发的过程!
java代理机制 JDK动态代理和cglib代理 详解
Java动态代理机制详解_动力节点Java学院整理,动力节点口口相传的Java黄埔军校
Java实现动态代理的两种方式。 相对来说cglib更加方便。可以实现为实现接口的类(非final类)
Java中提供了一个java.lang.reflect.Proxy类和java.lang.reflect.InvocationHandler接口来实现动态代理。代理类在运行时会根据被代理接口自动生成,并且可以通过InvocationHandler接口对方法进行增强。
1.什么是动态代理 ? 使用jdk的反射机制,创建对象的能力, 创建的是代理类的对象。 而不用你创建类文件。不用写java文件。 动态:在程序执行时,调用jdk提供的方法才能创建代理类的对象。 jdk动态代理,必须有接口...
主要介绍了Java动态代理语法Proxy类原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
一个是IoC,另一个是AOP,对于IoC,依赖注入不用多说了,而对于Spring的核心AOP来说,我们不但要知道怎么通过AOP来满足的我们的功能,我们更需要学习的是其底层是怎么样的一个原理,而AOP的原理是java的动态代理机制...
加载过程主要完成三件事情: (1)通过类的全限定名来获取定义此类的二进制字节流 (2)将这个类字节流代表的静态存储结构...(3)在堆中生成一个代表此类的java.lang.Class对象,作为访问方法区这些数据结构的入口。
java反射机制和动态代理的原理,熟悉反射机制和动态代理
本资源利用文档加源码的方式较详细的介绍了JDK 动态代理和Spring的AOP机制.相信对您理解相关方面的知识有很大作用.
java 代理模式实现代码及设计详解:动态代理模式、静态代理模式
031505_【第15章:Java反射机制】_动态代理笔记.pdf 031506_【第15章:Java反射机制】_工厂设计模式笔记.pdf 031601_【第16章:Annotation】_系统内建Annotation笔记.pdf 031602_【第16章:Annotation】_自定义...
(类的加载概述和加载时机) (类加载器的概述和分类) (获取class文件对象的三种方式) (通过反射获取无参构造方法并使用) (通过反射获取带参构造方法并使用) (通过反射获取私有构造方法并使用) ...(动态代理的概述和实现)
代理模式是我们比较常用的设计模式之一。其中新思想是为了提供额外的处理或者不同的操作而在实际对象与调用者之间插入一个代理对象。这些额外的操作通常需要与实际对象进行通信,代理模式一般涉及到的角色有: ...