设计模式之Proxy(代理)
来源:互联网 发布:腾讯视频制作软件 编辑:程序博客网 时间:2024/05/22 02:24
代理模式
介绍
代理模式,在我们日常开发中比较常用,使用也是比较广的一种设计模式,特别是在框架中出现是很普遍的。
代理模式主要涉及到几个部分,
一个是代理的抽象主题(可以是一个接口或者是一个抽象类),它定义好一个或者多个被代理的行为(每一个行为对应到代码是一个方法);
一个是抽象主题的具体实现类,实现的具体细节主要是取决于业务的需要,是代理的真实实现者;
另一个是代理者,也叫委托者,在代理模式这个体系中,代理者是对外的一个口子,即是说,我们需要调用被代理类的一个方法,其实是先返回一个代理类,然后我们调用的是代理类的方法,
由代理类的方法封装了被代理类的方法,这样一来,代理类可以在调用被代理类的方法时,可以执行一个额外的操作,比如记录相关日志、方法的执行时间、安全体检等等。
代理模式,又分为静态代理和动态代理。
由代码来进一步理解:
抽象主题,它只定义一个行为,用方法doWork来表示
一般来说,还会有一个生成代理类的工厂类
同样,先用一个接口来定义好生成代理类的行为规范
一个被代理的抽象对象,就要有个代理类,如果业务增多,被代理的抽象对象也会变多,随之而来是代理类也要跟着增加,静态代理就显得比较吃力;
如果被代理的抽象对象需要增加一个接口方法,或者减少方法,那么所有代理类也要跟着做修改,这样一来,对代理类的维护就显得比较繁重。
==============================
介绍
代理模式,在我们日常开发中比较常用,使用也是比较广的一种设计模式,特别是在框架中出现是很普遍的。代理模式主要涉及到几个部分,
一个是代理的抽象主题(可以是一个接口或者是一个抽象类),它定义好一个或者多个被代理的行为(每一个行为对应到代码是一个方法);
一个是抽象主题的具体实现类,实现的具体细节主要是取决于业务的需要,是代理的真实实现者;
另一个是代理者,也叫委托者,在代理模式这个体系中,代理者是对外的一个口子,即是说,我们需要调用被代理类的一个方法,其实是先返回一个代理类,然后我们调用的是代理类的方法,
由代理类的方法封装了被代理类的方法,这样一来,代理类可以在调用被代理类的方法时,可以执行一个额外的操作,比如记录相关日志、方法的执行时间、安全体检等等。
代理模式,又分为静态代理和动态代理。
一、静态代理
抽象主题、抽象主题的实现类和代理类都已经编写好一个java文件,已经被编译好成一个class文件,在程序运行时,已经知道是哪个代理类,哪个是被代理类,两者的关系都已经确定好的。由代码来进一步理解:
抽象主题,它只定义一个行为,用方法doWork来表示
public interface Subject { public boolean doWork(String argument);}抽象主题的实现类,也即是被代理的类,它是抽象主题类的真实实现类,实现了doWork方法的具体细节
public class RealSubject implements Subject{ @Override public boolean doWork(String argument) { for(int i = 0; i < 5000000; i++){ } return true; }}代理类,在调用被代理类的方法时,代理类进行了时间的计算。
public class ProxySubject implements Subject{ private Subject subject; public ProxySubject(Subject subject){ this.subject = Objects.requireNonNull(subject, "subject must not be null."); } @Override public boolean doWork(String argument) { long start = System.currentTimeMillis(); boolean result = subject.doWork(argument); long finish = System.currentTimeMillis(); String logString = String.format("subject:%s,method:%s,argument:%s,cost(ms):%d,result:%b", subject.getClass().getSimpleName(), "doWork", argument, finish - start, result); System.out.println(logString) return result; }}
一般来说,还会有一个生成代理类的工厂类
同样,先用一个接口来定义好生成代理类的行为规范
public interface ProxyFactory <T>{ public T newProxyInstance();}下面才是工厂类的真实实现类,针对不同的代理类,对应不同的工厂类。
public class SubjectProxyFactory implements ProxyFactory<Subject>{ @Override public Subject newProxyInstance() { return new ProxySubject(new RealSubject()); } }静态代理不足之处:
一个被代理的抽象对象,就要有个代理类,如果业务增多,被代理的抽象对象也会变多,随之而来是代理类也要跟着增加,静态代理就显得比较吃力;
如果被代理的抽象对象需要增加一个接口方法,或者减少方法,那么所有代理类也要跟着做修改,这样一来,对代理类的维护就显得比较繁重。
二,动态代理
JDK提供了动态代理,参照点击打开链接 0 0
- 设计模式之代理模式(Proxy)
- 设计模式之代理模式(Proxy)
- 设计模式之Proxy(代理模式)
- 【设计模式】之代理模式(Proxy)
- 设计模式之代理(proxy)模式
- 设计模式之(Proxy)代理模式
- 设计模式之代理模式(Proxy)
- 设计模式之代理模式(Proxy)
- 设计模式之代理模式(Proxy)
- 设计模式之代理模式(Proxy)
- 设计模式之代理模式(Proxy)
- 设计模式(六)之 Proxy(代理)
- 设计模式之Proxy(代理)
- 设计模式之Proxy(代理)
- 设计模式之Proxy(代理)
- 设计模式之Proxy(代理)
- 设计模式之Proxy(代理)
- 设计模式之Proxy(代理)
- C语言数组指针
- PowerBuilder动态SQL
- POJ3579 Median —— 二分
- 停靠窗口QDockWidget类
- tensorflow学习链接
- 设计模式之Proxy(代理)
- 三子棋
- 指针数组、数组指针、二重指针
- Break Standard Weight(模拟,暴力)
- HTML5文档结构代码
- CUDA优化策略概述
- OpenThreads库的使用-Atomic
- JAVA数据类型的转换(自动转换)
- 《机器学习实战》学习笔记---决策树