动态代理
来源:互联网 发布:罗马尼亚铁卫电影 知乎 编辑:程序博客网 时间:2024/06/07 18:36
在java动态代理机制中 有两个重要的类或接口,InvokedHandler (Interface) 或 Proxy(class),这个类和这个接口是我们实现动态代理时必须用到的。
每一个动态代理类都必须实现InvocationHandler接口.
eg:publicclass DynamicProxy implements InvocationHandler
InvocationHandler这个接口存在唯一一个方法 invoke 方法
每个代理实例都会关联到一个handler
handler对象的创建,以真实对象的实例为参数new 实例化自己的动态代理对象而获得handler对象。
eg: InvocationHandler handler = newDynamicProxy(代理真实对象实例);
创建动态代理对象
通过Proxy.newroxyInstance(ClassLoader loader, Class<?>[] interfaces, InvocationHandler h)获取。
参数解析:
ClassLoader :定义了由哪个ClassLoader对象来对生成的代理对象进行加载.可通过 handler.getClass().getClassLoader()获取。
Class Interface :一个Interface对象的数组,表示真实对象会提供哪些接口供代理对象调用。(会存在多个接口顾表示为数组类型)
InvocationHandler :一个InvocationHandler对象,表示的是当我这个动态代理对象在调用方法的时候,会关联到哪一个InvocationHandler对象上.
实例如下:
1.定义一个接口类
public interface Subject{ public void rent(); public void hello(String str);}2.定义Subject 接口类的实现类
public class RealSubject implements Subject{ @Override public void rent() { System.out.println("I want to rent my house"); } @Override public void hello(String str) { System.out.println("hello: " + str); }}3.定义动态代理类(每一个动态代理类都必须要实现 InvocationHandler 这个接口)
public class DynamicProxy implements InvocationHandler{ // 这个就是我们要代理的真实对象 private Object subject; // 构造方法,给我们要代理的真实对象赋初值 public DynamicProxy(Object subject) { this.subject = subject; } @Override public Object invoke(Object object, Method method, Object[] args) throws Throwable { // 在代理真实对象前我们可以添加一些自己的操作 System.out.println("before rent house"); System.out.println("Method:" + method); // 当代理对象调用真实对象的方法时,其会自动的跳转到代理对象关联的handler对象的invoke方法来进行调用 method.invoke(subject, args); 注:invoke 里面对应的subject 是该动态代理定义的private 对象。 // 在代理真实对象后我们也可以添加一些自己的操作 System.out.println("after rent house"); return null; }}4.定义类 实现调用接口Subject里的方法
public class Client{ public static void main(String[] args) { // 我们要代理的真实对象 Subject realSubject = new RealSubject(); // 我们要代理哪个真实对象,就将该对象传进去,最后是通过该真实对象来调用其方法的 InvocationHandler handler = new DynamicProxy(realSubject); /* * 通过Proxy的newProxyInstance方法来创建我们的代理对象,我们来看看其三个参数 * 第一个参数 handler.getClass().getClassLoader() ,我们这里使用handler这个类的ClassLoader对象来加载我们的代理对象 * 第二个参数realSubject.getClass().getInterfaces(),我们这里为代理对象提供的接口是真实对象所实行的接口,表示我要代理的是该真实对象,这样我就能调用这组接口中的方法了 * 第三个参数handler, 我们这里将这个代理对象关联到了上方的 InvocationHandler 这个对象上 */ Subject subject = (Subject)Proxy.newProxyInstance(handler.getClass().getClassLoader(), realSubject .getClass().getInterfaces(), handler); System.out.println(subject.getClass().getName()); subject.rent(); subject.hello("world"); }}
spring aop是动态代理的最佳表现。具体的信息见下篇
- 代理-->静态代理&动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- iOS 记录crash日志
- Unity的Android打包(Sqlite数据库使用)
- 调用优酷视频api
- 【Android实战】EventBus 更少的代码 更好的体验
- 起点
- 动态代理
- hdu 1050 Moving Tables
- 软件著作权和商业秘密权
- Shell中的${}、##和%%使用范例
- JSP——EL表达式
- 优化MyBatis配置文件中的配置_3
- PHP高效率写法
- java中Json工具的用法比较与性能测试
- Android 基础shape