java动态代理
来源:互联网 发布:位面淘宝txt下载 编辑:程序博客网 时间:2024/05/29 15:15
都知道Retrofit是通过动态代理来生成代理对象作为网络请求的发起者。
今天就来看下动态代理是怎么操作的。或者说是怎么让一个貌似接口的对象调用它的抽象方法呢?
先来看代码:
public static void main(String[] args) { Factory factory = new Factory(); Bird bird = factory.create(Bird.class); bird.fly();//输出结果为 flying...}interface Bird { void fly();}
这里代码通过一个Factory实例调用create方法,传入一个接口的class对象就可以返回一个接口的实例,可以调用接口中的方法fly()。
而在我们的静态代码中并没有一个类去实现了这个Bird接口(完整代码可以看下方)。那么这个对象到底是从哪里来的呢?
完整代码如下:
public class DynamicProxy { interface Bird { void fly(); } public static void main(String[] args) { Factory factory = new Factory(); Bird bird = factory.create(Bird.class); bird.fly();//输出结果为flying... } static class Factory implements InvocationHandler { public <T> T create(Class<T> target) { return (T) Proxy.newProxyInstance(target.getClassLoader(), new Class[]{target}, this); } public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println("flying..."); return null; } }}
在调用bird.fly()时,输出结果为flying...,很明显,代码中就如同开始所说的,并不存在一个实现了Bird接口的子类,而bird又实实在在调用了fly()方法。唯一的可能就是bird是接口的实例(或者说实现接口的子类的对象)。这里看起来似乎就有些诡异了。
当然编程没有魔法,这里只是利用到了Java的动态代理,通过Proxy.newProxyInstance()方法生成实现了指定接口的子类,然后返回了这个动态生成类的实例对象。
这个子类在调用接口中的方法时,其实调用的是InvocationHandler的invoke()方法。在此方法中会有对应参数的回调,可以根据这些参数做出合适的拦截/增强等操作。
都知道Retrofit是通过动态代理来生成代理对象作为网络请求的发起者。
今天就来看下动态代理是怎么操作的。或者说是怎么让一个貌似接口的对象调用它的抽象方法呢?
先来看代码:
public static void main(String[] args) { Factory factory = new Factory(); Bird bird = factory.create(Bird.class); bird.fly();//输出结果为 flying...}interface Bird { void fly();}
这里代码通过一个Factory实例调用create方法,传入一个接口的class对象就可以返回一个接口的实例,可以调用接口中的方法fly()。
而在我们的静态代码中并没有一个类去实现了这个Bird接口(完整代码可以看下方)。那么这个对象到底是从哪里来的呢?
完整代码如下:
public class DynamicProxy { interface Bird { void fly(); } public static void main(String[] args) { Factory factory = new Factory(); Bird bird = factory.create(Bird.class); bird.fly();//输出结果为flying... } static class Factory implements InvocationHandler { public <T> T create(Class<T> target) { return (T) Proxy.newProxyInstance(target.getClassLoader(), new Class[]{target}, this); } public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println("flying..."); return null; } }}
在调用bird.fly()时,输出结果为flying...,很明显,代码中就如同开始所说的,并不存在一个实现了Bird接口的子类,而bird又实实在在调用了fly()方法。唯一的可能就是bird是接口的实例(或者说实现接口的子类的对象)。这里看起来似乎就有些诡异了。
当然编程没有魔法,这里只是利用到了Java的动态代理,通过Proxy.newProxyInstance()方法生成实现了指定接口的子类,然后返回了这个动态生成类的实例对象。
这个子类在调用接口中的方法时,其实调用的是InvocationHandler的invoke()方法。在此方法中会有对应参数的回调,可以根据这些参数做出合适的拦截/增强等操作。
- Java 代理,动态代理
- [Java] Java 动态代理
- java代理及动态代理
- java代理模式--动态代理
- Java静态代理、动态代理
- Java 代理之 动态代理
- Java 代理与动态代理
- java静态代理,动态代理
- 代理模式&java动态代理
- Java代理与动态代理
- Java静态代理动态代理
- JAVA代理模式--动态代理
- java 代理和动态代理
- JAVA动态代理 代理模式
- Java动态代理--jdk代理
- Java动态代理--cglib代理
- Java 代理与动态代理
- java代理模式-动态代理
- c++设计模式之工厂模式
- 动态规划之线性动规钢条切割问题
- ros中2D_Slam说明: turtlebot+kinect改写成turtlebot+laser(hokuyo)
- IOS下Libevent编译步骤,及引入Xcode备忘
- Intelij导入maven项目并部署到tomcat
- java动态代理
- 阅读源代码的感想
- java8新特性 Lambda表达式详解
- Photoshop-设计导航
- Android删除手机本地图片并同步到本地图片媒体库
- mysql 存储过程、游标及逐行处理的配合使用
- BZOJ 1673: [Usaco2005 Dec]Scales 天平 启发式搜索
- ajax请求二进制流图片并渲染到html中img标签
- 《深入理解java虚拟机》学习笔记(5)--虚拟机字节码执行引擎