代理模式与模板模式

上传人:宝路 文档编号:47882357 上传时间:2018-07-05 格式:PPTX 页数:25 大小:211.74KB
返回 下载 相关 举报
代理模式与模板模式_第1页
第1页 / 共25页
代理模式与模板模式_第2页
第2页 / 共25页
代理模式与模板模式_第3页
第3页 / 共25页
代理模式与模板模式_第4页
第4页 / 共25页
代理模式与模板模式_第5页
第5页 / 共25页
点击查看更多>>
资源描述

《代理模式与模板模式》由会员分享,可在线阅读,更多相关《代理模式与模板模式(25页珍藏版)》请在金锄头文库上搜索。

1、依赖(Dependency):虚线箭头表示:元素A的变化会影响元素B,但反之不成 立,那么B和A的关系是依赖关系,B依赖A;类属关系和实现关系在语义上 讲也是依赖关系,但由于其有更特殊的用途,所以被单独描述。 uml中用带箭头的虚线表示Dependency关系,箭头指向被依赖元素。关联(Association):实线箭头表示:元素间的结构化关系,是一种弱关系, 被关联的元素间通常可以被独立的考虑。uml中用实线表示Association关系 ,箭头指向被依赖元素。其中带箭头是单向 关联,无箭头即一个实线是双向关联。UML类图说明聚合(Aggregation):带空心菱形头表示:关联关系的一种特

2、例,表示部分 和整体(整体 has a 部分)的关系。uml中用带空心菱形头的实线表示 Aggregation关系,菱形头指向整体。合成/组合(Composition):带实心菱形头的实线表示:组合是聚合关系的变 种,表示元素间更强的组合关系。 如果是组合关系,如果整体被破坏则 个体一定会被破坏,而聚合的个体则 可能是被多个整体所共享的,不一定 会随着某个整体的破坏而被破坏。 uml中用带实心菱形头的实线表示Composition关系,菱形头指向整体。泛化(Generalization):通常所说的继承(特殊个体 is kind of 一般个体)关 系,不必多解释了。uml中用带空心箭头的实线

3、线表示Generalization关系 ,箭头指向一般个体。实现(Realize):元素A定义一个约定,元素B实现这个约定,则B和A的关系 是Realize,B realize A。这个关系最常用于接口。uml中用空心箭头和虚线 表示Realize关系,箭头指向定义约定的元素。代理模式的定义 代理模式(Proxy Pattern), 为其他对象提供一种代理以 控制对这个对象的访问。在某些情况下 ,一个客户不 想或者 不能直接引用另一个对象,而代理对象可以在客户端和目标对 象之间起到中介的作用。 代理模式一般涉及到的角色有: 抽象角色:声明真实对象和代理对象的共同接口; 代理角色:代理对象角色内

4、部含有对真实对象的引用,从而可 以操作真实对象,同时代理对象提供与真实对象相同的接口以 便在任何时刻都能代替真实对象。并且,代理对象可以在执行 真实对象操作时,附加其他的操作,相当于对真实对象进行封 装。 真实角色:代理角色所代表的真实对象,是我们最终要引用的 对象。代理模式的基本UML类图Subject obj = new Proxy ()代理模式的基本时序图 动机1.为了在我们确实需要这个对象时才对它进行创 建和初始化。2.用户希望程序和某个对象打交道,程序不希望 用户直接访问该对象为什么要使用Proxy模式?/抽象角色: abstract public class Subject abs

5、tract public void request(); /真实角色:实现了Subject的request()方法。 public class RealSubject extends Subjectpublic RealSubject() public void request()System.out.println(“From real subject.“); 代理实例/代理角色: public class ProxySubject extends Subjectprivate RealSubject realSubject; /以真实角色作为代理角色属性 public ProxySubje

6、ct() public void request() /该方法封装了真实对象的request方法 preRequest(); if( realSubject = null )realSubject = new RealSubject();realSubject.request(); /此处执行真实对象的request方法 postRequest(); private void preRequest() /something you want to do before requesting private void postRequest() /something you want to do

7、after requesting /客户端调用: Subject sub=new ProxySubject(); Sub.request();由以上代码可以看出,客户实际需要调用的是RealSubject类的 request()方法,现在用ProxySubject来代理RealSubject类,同样达到目 的,同时还封装了其他方法(preRequest(),postRequest(),可以处理一些 其他问题。 另外,如果要按照上述的方法使用代理模式,那么真实角色必须是 事先已经存在的,并将其作为代理对象的内部属性。但是实际使用时,一 个真实角色必须对应一个代理角色,如果大量使用会导致类的急剧膨

8、胀; 此外,如果事先并不知道真实角色,该如何使用代理呢?这个问题可以通过Java的动态代理类来解决。动态代理所谓Dynamic Proxy是这样一种class:它是在运行时生成的class ,在生成它时你必须提供一组interface给它,然后该class就宣称它实 现了这些interface。你当然可以把该class的实例当作这些interface中 的任何一个来用。当然啦,这个Dynamic Proxy其实就是一个Proxy, 它不会替你作实质性的工作,在生成它的实例时你必须提供一个 handler,由它接管实际的工作。Java动态代理类位于Java.lang.reflect包下,一般主要

9、涉及到以下 两个类:(1). Interface InvocationHandler:该接口中仅定义了一个方法 Object:invoke(Object obj,Method method, Object args)。在实际使 用时,第一个参数obj一般是指代理类,method是被代理的方法,如 上例中的request(),args为该方法的参数数组。这个抽象方法在代理 类中动态实现。(2).Proxy:该类即为动态代理类,作用类似于上例中的ProxySubject, 其中主要包含以下内容:a)Protected Proxy(InvocationHandler h):构造函数, 参数为 Inv

10、ocationHandler 实现类的实例。 b)Static Class getProxyClass (ClassLoader loader, Class interfaces) :获得一个代理类,其中loader是类装载器,interfaces是真实类所 拥有的全部接口的数组。 c)Static Object newProxyInstance(ClassLoader loader, Class interfaces, InvocationHandler h):返回代理类的一个实例,返回后 的代理类可以当作被代理类使用(可使用被代理类的在Subject接口中 声明过的方法)。在使用动态代理类

11、时,我们必须实现InvocationHandler接口,以第 一个示例为例:/抽象角色(之前是抽象类,此处应改为接口): public interface Subjectpublic void request(); /具体角色RealSubject:实现了Subject接口的request()方法。 public class RealSubject implements Subject public RealSubject()public void request() System.out.println(“From real subject.“); /代理角色: import java.la

12、ng.reflect.Method; import java.lang.reflect.InvocationHandler; public class DynamicSubject implements InvocationHandlerprivate Object target; public DynamicSubject(Object target) this. target = target; public Object invoke(Object proxy, Method method, Object args) throws Throwable System.out.println

13、(“before calling “ + method); method.invoke(sub,args); System.out.println(“after calling “ + method); return null; /客户端测试 import java.lang.reflect.InvocationHandler; import java.lang.reflect.Proxy; public class Client static public void main(String args) throws ThrowableRealSubject rs = new RealSubj

14、ect(); /在这里指定被代理类InvocationHandler ds = new DynamicSubject(rs); /初始化代理类Subject subject = (Subject) Proxy.newProxyInstance(Subject.class.getClassLoader(), rs.getClass().getInterfaces(),ds);subject.request(); 通过这种方式,被代理的对象(RealSubject)可以在运行时动态改变, 需要控制的接口(Subject接口)可以在运行时改变,控制的方式 (DynamicSubject类)也可以动态

15、改变,从而实现了非常灵活的动态代理关 系。代理模式的应用一般来说分为几种: 远程(Remote)代理:也就是为一个对象在不同的地址空间提供局部代表。这样可以隐藏一个对象存在于不同地址空间的事实。 虚拟(Virtual)代理:根据需要将一个资源消耗很大或者比较复杂的对象延迟的真正需要时才创建。比如说你打开一个很大的HTML网页时,里面可能有很多的文字和图片,但你还是可以很快的打开它,此时你所看到的是所有的文字,但图片却是一张张的下载后才能看到。那些未打开的图片框,就是通过虚拟代理来代替了真实的图片,此时代理存储了真实图片的路径和尺寸。 保护(Protect or Access)代理:控制对一个对

16、象的访问权限。一般用于对象有 不同权限的时候。 智能引用(Smart Reference)代理:当调用真实对象时,代理出来另外一些事,提供比对目标对象额外的服务。如:计算真实对象的引用次数,这样当该对象没有引用时,可以自动释放它;或当第一次引用一个持久对象时,将它装入内存;或在访问一个实际对象前,检查是否已经锁定它,以确保其它对象不能改变它。它们都是通过代理在访问一个对象时附加一些内务处理。远程代理( Remote Proxy )为一个对象在不同的地址空间提供局部代表。这样可以隐藏 一个对象存在于不同地址空间的事实。RMI(remote method invocation)是一种分布式技术,使用RMI 可以让一个虚拟机上的应用程序请求调用位于网络上另一个JVM 上的对象方法。RMI不希望客户应用程序直接与远程对象打交道 ,代替地让应用程序和远程对象的代理打交道。RMI会生成一个 存根:一种

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 中学教育 > 教学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号