Java设计模式之动态代理模式实例分析
本文实例讲述了Java设计模式之动态代理模式。分享给大家供大家参考,具体如下:
前面介绍了静态代理模式,动态代理比静态代理模式更加强大。它能在程序运行时动态的生成代理对象。所谓动态代理类是在运行时生成的class,在生成它时,你必须提供一组interface给它,则动态代理类就宣称它实现了这些interface。当然,动态代理类就充当一个代理,你不要企图它会帮你干实质性的工作,在生成它的实例时你必须提供一个handler,由它接管实际的工作。
动态代理的角色和静态代理的角色一样:
① 抽象角色:真实对象和代理对象的共同接口。其中声明真实对象和代理对象需要做的事。
② 真实角色:实现抽象角色,定义真实角色所要实现的业务逻辑,供代理角色调用。
③ 动态代理角色:需要实现InvocationHandler接口,并且实现其中的invoke方法。动态代理觉得持有一个Object类型引用,这个表示需要动态代理的角色。定义为Object类型,表示可动态代理任何类型的对象。
以下给出一个简单的动态代理模式的简单的代码实例:
1. 抽象角色:真实对象和代理对象的共同接口。其中声明真实对象和代理对象需要做的事。
package com.tydic.dynamicproxy; public interface Subject { public void request(); }
2. 真实角色:需要实现抽象角色,是被代理的对象。
package com.tydic.dynamicproxy; public class RealSubject implements Subject { @Override public void request() { System.out.println("from real subject!"); } }
3. 动态代理角色:需要实现InvocationHandler接口,并重写接口里面的invoke方法public Object invoke(Object proxy, Method method, Object[] args)
。invoke方法有三个参数。参数proxy指代理类,method表示被代理的方法,args为method中的参数数组,返回值Object为代理实例的方法调用返回的值。这个抽象方法在代理类中动态实现。
package com.tydic.dynamicproxy; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; public class DynamicSubject implements InvocationHandler { private Object sub;//被代理的对象 public DynamicSubject(Object obj) { this.sub = obj; } @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println("before calling:" + method); //可以在被代理的方法前后添加功能 method.invoke(sub, args); System.out.println("after calling:" + method); return null; } }
4. 编写客户端代码:需要用到一个Proxy类。Proxy类所有动态代理类的父类,提供用于创建动态代理类和实例的静态方法。Proxy类有一个静态方法public static Object newProxyInstance(ClassLoader loader, Class<?>[] interfaces, InvocationHandler h)
。第一个参数表示动态代理类的类加载器,第二个是动态代理类应该要实现的接口的Class数组,第三个参数是InvocationHandler 对象,当动态代理调用需要代理的方法时,InvocationHandler 对象的invoke方法会得到调用。
package com.tydic.dynamicproxy; import java.lang.reflect.Proxy; public class Client { public static void main(String[] args) { Subject subject = new RealSubject(); DynamicSubject handle = new DynamicSubject(subject); //动态的生成代理对象 Subject sub = (Subject) Proxy.newProxyInstance(DynamicSubject.class.getClassLoader(), subject.getClass().getInterfaces(), handle); sub.request();//实际是handle的invoke方法得到了调用 } }
更多java相关内容感兴趣的读者可查看本站专题:《Java面向对象程序设计入门与进阶教程》、《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》
希望本文所述对大家java程序设计有所帮助。
- Day5上午解题报告
- [编程经验] Pandas中比较好用的几个方法
- [编程经验] Elasticsearch 初识
- 2017.10.26水题大作战部分题解
- 2017.10.27涩会题大乱斗部分题解
- 【 关关的刷题日记50】 Leetcode 345. Reverse Vowels of a String
- Day1上午解题报告
- 【 关关的刷题日记51】 Leetcode 67. Add Binary
- 【 关关的刷题日记53】 Leetcode 100. Same Tree
- Day1下午解题报告
- 【关关的刷题日记54】Leetcode 226. Invert Binary Tree
- Day2上午解题报告
- 【关关的刷题日记55】Leetcode 404. Sum of Left Leaves
- CSS选择器详解
- java教程
- Java快速入门
- Java 开发环境配置
- Java基本语法
- Java 对象和类
- Java 基本数据类型
- Java 变量类型
- Java 修饰符
- Java 运算符
- Java 循环结构
- Java 分支结构
- Java Number类
- Java Character类
- Java String类
- Java StringBuffer和StringBuilder类
- Java 数组
- Java 日期时间
- Java 正则表达式
- Java 方法
- Java 流(Stream)、文件(File)和IO
- Java 异常处理
- Java 继承
- Java 重写(Override)与重载(Overload)
- Java 多态
- Java 抽象类
- Java 封装
- Java 接口
- Java 包(package)
- Java 数据结构
- Java 集合框架
- Java 泛型
- Java 序列化
- Java 网络编程
- Java 发送邮件
- Java 多线程编程
- Java Applet基础
- Java 文档注释
- 推荐系统中的常用算法——DeepWalk算法
- TypeError: cannot unpack non-iterable NoneType object
- 原型模式
- Spring 整合 Mybatis
- 数据库PostrageSQL-关闭服务器
- 快速配置Azure DevOps代理服务器
- 数据库PostrageSQL-管理内核资源
- airtest操作夜神模拟器adb冲突解决办法
- 数据库PostrageSQL-启动数据库服务器
- 数据库PostrageSQL-PostgreSQL用户账户创建一个数据库集簇
- 轻松上手SpringBoot Security + JWT Hello World示例
- [Go] Golang发送http GET请求
- Windows系统快速安装Superset 0.37
- 商业数据分析从入门到入职(3)Excel进阶应用
- python列表练习