浅析代理模式
来源:互联网 发布:led显示屏软件密码 编辑:程序博客网 时间:2024/06/06 05:26
代理模式的定义:对其他对象提供一种代理以控制对这个对象的访问。
代理模式的主要作用:是为其他对象提供一种代理以控制对这个对象的访问。在某些情况下,一个对象不想或者不能直接引用另一个对象,而代理对象可以在客户端和目标对象之间起到中介的作用。
代理模式涉及的角色:
1:抽象角色--声明了代理主题和真实主题的公共接口,使任何需要真实主题的地方都能用代理主题代替.2:代理角色--含有真实主题的引用,从而可以在任何时候操作真实主题,代理主题功过提供和真实主题相同的接口,使它可以随时代替真实主题.代理主题通过持有真实主题的引用,不但可以控制真实主题的创建或删除,可以在真实主题被调用前进行拦截,或在调用后进行某些操作.
3:真实代理对象--定义了代理角色所代表的具体对象. 就是我们最终要引用的对象
代理模式又分为动态代理和静态代理:首先来看看静态代理:
有一个用户类接口有一个抽象work的方法。然后有一个实现这个接口的类。然后用抽象代理帮我们代理创建这个实现类的对象。
public interface UserDao {public void insert(String name);public void test();}public class UserDaoImpl implements UserDao {@Overridepublic void insert(String name) {System.out.println("你好,"+name);}@Overridepublic void test() {System.out.println("test success......");}}然后再创建一个代理类:
public class UserProxy implements UserDao {private UserDaoImpl userdaoImpl;//被代理的类public UserProxy(UserDaoImpl userdaoImpl) {this.userdaoImpl = userdaoImpl;}@Overridepublic void insert(String name) {validate();userdaoImpl.insert(name);log();}@Overridepublic void test() {validate();userdaoImpl.test();log();}public void validate(){System.out.println("权限验证");}public void log(){System.out.println("记录日志");}}然后就可以测试了:
public static void main(String[] args) {UserProxy up=new UserProxy(new UserDaoImpl());up.insert("fdsa");System.out.println("-----------");up.test();}这就是静态代理:可以自动帮你生成这个对象。在代理类中你可以随意想插入什么插入什么。想删除不想要的操作就删除。非常的透明式的一个设计模式。而动态代理类就更高级了。就不用写这么多代码了。主要修改代理类就能跑了。。
public class UserProxy implements InvocationHandler {private Object obj;//被代理的对象public void validate(){//执行方法前的动作System.out.println("权限验证");}public void log(){//执行方法后的动作System.out.println("记录日志");}/** * * @param proxy 代理对象实例 * @param method 执行的方法 * @param args 方法中的参数列表 * @return 返回一个代理实例 * @throws Throwable */@Overridepublic Object invoke(Object proxy, Method method, Object[] args)throws Throwable {validate();Object o=(Object)method.invoke(obj, args);log();return o;}public Object createObject(Object object){this.obj = object;return Proxy.newProxyInstance(obj.getClass().getClassLoader(), object.getClass().getInterfaces(), this);}}当然测试类也要改了:
UserProxy up=new UserProxy();UserDao userdao=(UserDao)up.createObject(new UserDaoImpl());userdao.insert("young");userdao.test();相比静态代理。动态代理非常灵活轻巧。能省很多事。在spring中的AOP其实就是贯穿着这一设计模式来着的。
- 浅析代理模式
- 浅析代理模式
- 代理模式浅析
- 静态代理模式浅析
- 浅析代理模式
- 设计模式之代理模式浅析
- 浅析设计模式之代理模式
- 浅析“代理模式”实现spring事务管理
- 浅析JAVA设计模式之代理模式(一)
- 浅析JAVA设计模式之代理模式(二)
- 浅析JAVA设计模式之代理模式(三)
- 浅析JAVA设计模式之代理模式(四)
- 浅析JAVA设计模式之代理模式(五)
- 浅析JAVA设计模式之代理模式(六)
- 浅析JAVA设计模式之代理模式(七)
- java 设计模式 —— 浅析代理模式
- 浅析正向代理、反向代理
- IOS代理浅析
- Open Session in View
- linux find查找命令
- 使用Objective-C解压缩ZIP文件教程
- 企业架构-分析的核心思路
- arm芯片中的浮点运算(二)
- 浅析代理模式
- EclipsePHP Studio--PHP的IDE开发软件
- 给ubuntu下虚拟机virtualbox中的ubuntu安装增强功能
- C语言全局变量多文件使用
- 递归的例子
- WampServer 5 集成环境 Ver 2.0c
- uva 106 Street Numbers
- 整数划分n划分成不大于k的放法数
- CVS如何从Sourceforge 上 CheckOUt 源代码