《第四章结构型模式.ppt》由会员分享,可在线阅读,更多相关《第四章结构型模式.ppt(196页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、Institute of Computer Software 杨明根2教学内容教学内容结构型模式结构型模式适配器模式适配器模式组合模式组合模式外观模式外观模式代理模式代理模式Institute of Computer Software 杨明根结构型模式结构型模式概述 结构型模式(Structural Pattern)描述如何将类或者对象结合在一起形成更大的结构,就像搭积木,可以通过简单积木的组合形成复杂的、功能更为强大的结构。Institute of Computer Software 杨明根结构型模式结构型模式概述根据这一点,结构型模式可以分为类结构型模式和对象结构型模式:类结构型模式关心类
2、的组合,由多个类可以组合成一个更大的系统,在类结构型模式中一般只存在继承关系和实现关系。对象结构型模式关心类与对象的组合,通过关联关系使得在一个类中定义另一个类的实例对象,然后通过该对象调用其方法。根据“合成复用原则”,在系统中尽量使用关联关系来替代继承关系,因此大部分结构型模式都是对象结构型模式。Institute of Computer Software 杨明根结构型模式结构型模式结构型模式简介结构型模式简介适配器模式适配器模式(Adapter)桥接模式桥接模式(Bridge)组合模式组合模式(Composite)装饰模式装饰模式(Decorator)外观模式外观模式(Facade)享元模
3、式享元模式(Flyweight)代理模式代理模式(Proxy)Institute of Computer Software 杨明根Adapter(适配器)模式“不合适的插座”你的电脑的插头是三相的而墙上的插座只有两相的插头和插座的“接口”不匹配,怎么办?Adapter(适配器)模式HuntBird游戏中,希望增加一种鸟类“鸭子”但是发现以前有一个系统中已经有了“鸭子”类,希望重用老代码Adapter(适配器)模式新老代码接口不一致Adapter(适配器)模式疑问把老代码修改一下不就可以了么?如下:Adapter(适配器)模式否定首先,老代码不一定允许修改比如可能根本没有代码,只有链接库其次,修
4、改代码工作量可能很大容易出错还记得“开-闭原则”么Adapter(适配器)模式应用(对象)适配器模式实现接口转换Adapter(适配器)模式应用(对象)适配器模式实现接口转换Adapter(适配器)模式理解1:接口转换客户客户客户客户(鸟鸟鸟鸟)被适配者被适配者被适配者被适配者(鸭子鸭子鸭子鸭子)适配器适配器适配器适配器请求请求请求请求转换后的请求转换后的请求转换后的请求转换后的请求Adapter(适配器)模式叫叫叫叫呷呷叫呷呷叫呷呷叫呷呷叫Adapter(适配器)模式理解2:重新包装,改变接口Adapter(适配器)模式类适配器Institute of Computer Software 杨
5、明根适配器模式模式动机在软件开发中采用类似于电源适配器的设计和编码技巧被称为适配器模式。通常情况下,客户端可以通过目标类的接口访问它所提供的服务。有时,现有的类可以满足客户类的功能需要,但是它所提供的接口不一定是客户类所期望的,这可能是因为现有类中方法名与目标类中定义的方法名不一致等原因所导致的。在这种情况下,现有的接口需要转化为客户类期望的接口,这样保证了对现有类的重用。如果不进行这样的转化,客户类就不能利用现有类所提供的功能,适配器模式可以完成这样的转化。Institute of Computer Software 杨明根适配器模式模式动机在适配器模式中可以定义一个包装类,包装不兼容接口的
6、对象,这个包装类指的就是适配器(Adapter),它所包装的对象就是适配者(Adaptee),即被适配的类。适配器提供客户类需要的接口,适配器的实现就是把客户类的请求转化为对适配者的相应接口的调用。也就是说:当客户类调用适配器的方法时,在适配器类的内部将调用适配者类的方法,而这个过程对客户类是透明的,客户类并不直接访问适配者类。因此,适配器可以使由于接口不兼容而不能交互的类可以一起工作。这就是适配器模式的模式动机。Institute of Computer Software 杨明根适配器模式模式定义适配器模式(Adapter Pattern):将一个接口转换成客户希望的另一个接口,适配器模式使
7、接口不兼容的那些类可以一起工作,其别名为包装器(Wrapper)。适配器模式既可以作为类结构型模式,也可以作为对象结构型模式。Institute of Computer Software 杨明根适配器模式模式定义Convert the interface of a class into another interface clients expect.Adapter lets classes work together that couldnt otherwise because of incompatible interfaces.Frequency of use:medium high I
8、nstitute of Computer Software 杨明根适配器模式模式结构类适配器Institute of Computer Software 杨明根适配器模式模式结构对象适配器Institute of Computer Software 杨明根适配器模式模式结构适配器模式包含如下角色:Target:目标抽象类Adapter:适配器类Adaptee:适配者类Client:客户类Institute of Computer Software 杨明根适配器模式模式分析典型的类适配器代码:public class Adapter extends Adaptee implements Targ
9、etpublic void request()specificRequest();Institute of Computer Software 杨明根适配器模式模式分析典型的对象适配器代码:public class Adapter extends Targetprivate Adaptee adaptee;public Adapter(Adaptee adaptee)this.adaptee=adaptee;public void request()adaptee.specificRequest();适配器模式适配器模式实例与解析实例一:仿生机器人 现需要设计一个可以模拟各种动物行为的机器人,
10、在机器人中定义了一系列方法,如机器人叫喊方法cry()、机器人移动方法move()等。如果希望在不修改已有代码的基础上使得机器人能够像狗一样叫,像狗一样跑,使用适配器模式进行系统设计。适配器模式适配器模式实例与解析实例一:仿生机器人 适配器模式适配器模式实例与解析实例一:仿生机器人 参考代码演示演示演示演示Institute of Computer Software 杨明根适配器模式适配器模式实例与解析实例二:加密适配器某系统需要提供一个加密模块,将用户信息(如密码等机密信息)加密之后再存储在数据库中,系统已经定义好了数据库操作类。为了提高开发效率,现需要重用已有的加密算法,这些算法封装在一些
11、由第三方提供的类中,有些甚至没有源代码。使用适配器模式设计该加密模块,实现在不修改现有类的基础上重用第三方加密方法。Institute of Computer Software 杨明根适配器模式适配器模式实例与解析实例二:加密适配器Institute of Computer Software 杨明根适配器模式适配器模式实例与解析实例二:加密适配器参考代码演示演示演示演示Institute of Computer Software 杨明根适配器模式模式优缺点适配器模式的优点如下:将目标类和适配者类解耦,通过引入一个适配器类来重用现有的适配者类,而无需修改原有代码。增加了类的透明性和复用性,将具体
12、的实现封装在适配者类中,对于客户端类来说是透明的,而且提高了适配者的复用性。灵活性和扩展性都非常好,通过使用配置文件,可以很方便地更换适配器,也可以在不修改原有代码的基础上增加新的适配器类,完全符合“开闭原则”。Institute of Computer Software 杨明根适配器模式模式优缺点类适配器模式还具有如下优点:由于适配器类是适配者类的子类,因此可以在适配器类中置换一些适配者的方法,使得适配器的灵活性更强。类适配器模式的缺点如下:对于Java、C#等不支持多重继承的语言,一次最多只能适配一个适配者类,而且目标抽象类只能为抽象类,不能为具体类,其使用有一定的局限性,不能将一个适配者
13、类和它的子类都适配到目标接口。Institute of Computer Software 杨明根适配器模式模式优缺点对象适配器模式还具有如下优点:一个对象适配器可以把多个不同的适配者适配到同一个目标,也就是说,同一个适配器可以把适配者类和它的子类都适配到目标接口。对象适配器模式的缺点如下:与类适配器模式相比,要想置换适配者类的方法就不容易。如果一定要置换掉适配者类的一个或多个方法,就只好先做一个适配者类的子类,将适配者类的方法置换掉,然后再把适配者类的子类当做真正的适配者进行适配,实现过程较为复杂。Institute of Computer Software 杨明根适配器模式模式适用环境在以
14、下情况下可以使用适配器模式:系统需要使用现有的类,而这些类的接口不符合系统的需要。想要建立一个可以重复使用的类,用于与一些彼此之间没有太大关联的一些类,包括一些可能在将来引进的类一起工作。Institute of Computer Software 杨明根适配器模式模式应用(1)Sun公司在1996年公开了Java语言的数据库连接工具JDBC,JDBC使得Java语言程序能够与数据库连接,并使用SQL语言来查询和操作数据。JDBC给出一个客户端通用的抽象接口,每一个具体数据库引擎(如SQL Server、Oracle、MySQL等)的JDBC驱动软件都是一个介于JDBC接口和数据库引擎接口之间
15、的适配器软件。抽象的JDBC接口和各个数据库引擎API之间都需要相应的适配器软件,这就是为各个不同数据库引擎准备的驱动程序。Institute of Computer Software 杨明根适配器模式模式应用(2)在Spring AOP框架中,对BeforeAdvice、AfterAdvice、ThrowsAdvice三种通知类型借助适配器模式来实现。public interface AdvisorAdapter /将一个Advisor适配成MethodInterceptor MethodInterceptor getInterceptor(Advisor advisor);/判断此适配器是
16、否支持特定的Advice boolean supportsAdvice(Advice advice);Institute of Computer Software 杨明根适配器模式模式应用(3)在JDK类库中也定义了一系列适配器类,如在mon包中定义的InputStreamAdapter类,用于包装ImageInputStream接口及其子类对象。public class InputStreamAdapter extends InputStream ImageInputStream stream;public InputStreamAdapter(ImageInputStream stream
17、)super();this.stream=stream;public int read()throws IOException return stream.read();public int read(byte b,int off,int len)throws IOException return stream.read(b,off,len);Institute of Computer Software 杨明根适配器模式模式应用(3)在JDK类库中也定义了一系列适配器类,如在mon包中定义的InputStreamAdapter类,用于包装ImageInputStream接口及其子类对象。pub
18、lic class InputStreamAdapter extends InputStream ImageInputStream stream;public InputStreamAdapter(ImageInputStream stream)super();this.stream=stream;public int read()throws IOException return stream.read();public int read(byte b,int off,int len)throws IOException return stream.read(b,off,len);Insti
19、tute of Computer Software 杨明根适配器模式模式扩展缺省适配器模式适配者接口 缺省适配器类 具体业务类 Institute of Computer Software 杨明根适配器模式模式扩展缺省适配器模式Institute of Computer Software 杨明根适配器模式模式扩展双向适配器 在对象适配器的使用过程中,如果在适配器中同时包含对目标类和适配者类的引用,适配者可以通过它调用目标类中的方法,目标类也可以通过它调用适配者类中的方法,那么该适配器就是一个双向适配器。Institute of Computer Software 杨明根适配器模式模式扩展双向适
20、配器 组合模式Institute of Computer Software 杨明根组合模式模式动机组合模式模式动机对于树形结构,当容器对象(如文件夹)的某一个方法被调用时,将遍历整个树形结构,寻找也包含这个方法的成员对象(可以是容器对象,也可以是叶子对象,如子文件夹和文件)并调用执行。由于容器对象和叶子对象在功能上的区别,在使用这些对象的客户端代码中必须有区别地对待容器对象和叶子对象,而实际上大多数情况下客户端希望一致地处理它们,因为对于这些对象的区别对待将会使得程序非常复杂。组合模式模式动机组合模式描述了如何将容器对象和叶子对象进行递归组合,使得用户在使用时无需对它们进行区分,可以一致地对待
21、容器对象和叶子对象,这就是组合模式的模式动机。组合模式模式定义组合模式(Composite Pattern):组合多个对象形成树形结构以表示“整体部分”的结构层次。组合模式对单个对象(即叶子对象)和组合对象(即容器对象)的使用具有一致性。组合模式又可以称为“整体部分”(Part-Whole)模式,属于对象的结构模式,它将对象组织到树结构中,可以用来描述整体与部分的关系。组合模式模式定义Compose objects into tree structures to represent part-whole hierarchies.Composite lets clients treat indi
22、vidual objects and compositions of objects uniformly.Frequency of use:medium high 组合模式模式结构组合模式模式结构组合模式包含如下角色:Component:抽象构件Leaf:叶子构件Composite:容器构件Client:客户类组合模式模式分析组合模式的关键是定义了一个抽象构件类,它既可以代表叶子,又可以代表容器,而客户端针对该抽象构件类进行编程,无需知道它到底表示的是叶子还是容器,可以对其进行统一处理。同时容器对象与抽象构件类之间还建立一个聚合关联关系,在容器对象中既可以包含叶子,也可以包含容器,以此实现递归
23、组合,形成一个树形结构。组合模式模式分析文件系统组合模式结构图:组合模式模式分析典型的抽象构件角色代码:public abstract class Componentpublic abstract void add(Component c);public abstract void remove(Component c);public abstract Component getChild(int i);public abstract void operation();组合模式模式分析典型的叶子构件角色代码:public class Leaf extends Componentpublic v
24、oid add(Component c)/异常处理或错误提示 public void remove(Component c)/异常处理或错误提示 public Component getChild(int i)/异常处理或错误提示 public void operation()/实现代码 组合模式模式分析典型的容器构件角色代码:public class Composite extends Componentprivate ArrayList list=new ArrayList();public void add(Component c)list.add(c);public void remo
25、ve(Component c)list.remove(c);public Component getChild(int i)(Component)list.get(i);public void operation()for(Object obj:list)(Component)obj).operation();组合模式组合模式实例与解析实例一:水果盘在水果盘(Plate)中有一些水果,如苹果(Apple)、香蕉(Banana)、梨子(Pear),当然大水果盘中还可以有小水果盘,现需要对盘中的水果进行遍历(吃),当然如果对一个水果盘执行“吃”方法,实际上就是吃其中的水果。使用组合模式模拟该场景。
26、组合模式组合模式实例与解析实例一:水果盘组合模式组合模式实例与解析实例一:水果盘参考代码演示演示演示演示组合模式组合模式实例与解析实例二:文件浏览文件有不同类型,不同类型的文件其浏览方式有所区别,如文本文件和图片文件的浏览方式就不相同。对文件夹的浏览实际上就是对其中所包含文件的浏览,而客户端可以一致地对文件和文件夹进行操作,无需关心它们的区别。使用组合模式来模拟文件的浏览操作。组合模式组合模式实例与解析实例二:文件浏览从前有座山从前有座山,山上有座庙,庙里有个,山上有座庙,庙里有个老老和尚和尚,在给,在给小和尚小和尚讲故事,讲的什么呢,讲故事,讲的什么呢,讲的是:讲的是:从前有座山,山上有座庙
27、,庙里有个老从前有座山,山上有座庙,庙里有个老和尚,在给小和尚讲故事,讲的什么呢,和尚,在给小和尚讲故事,讲的什么呢,讲的是:讲的是:从前有座山,山上有座庙,庙里有个老从前有座山,山上有座庙,庙里有个老和尚,在给小和尚讲故事,讲的什么呢,和尚,在给小和尚讲故事,讲的什么呢,讲的是:讲的是:组合模式模式优缺点组合模式的优点如下:可以清楚地定义分层次的复杂对象,表示对象的全部或部分层次,使得增加新构件也更容易。客户端调用简单,客户端可以一致的使用组合结构或其中单个对象。定义了包含叶子对象和容器对象的类层次结构,叶子对象可以被组合成更复杂的容器对象,而这个容器对象又可以被组合,这样不断递归下去,可以
28、形成复杂的树形结构。更容易在组合体内加入对象构件,客户端不必因为加入了新的对象构件而更改原有代码。组合模式模式优缺点组合模式的缺点如下:使设计变得更加抽象,对象的业务规则如果很复杂,则实现组合模式具有很大挑战性,而且不是所有的方法都与叶子对象子类都有关联。增加新构件时可能会产生一些问题,很难对容器中的构件类型进行限制。组合模式模式适用环境在以下情况下可以使用组合模式:需要表示一个对象整体或部分层次,在具有整体和部分的层次结构中,希望通过一种方式忽略整体与部分的差异,可以一致地对待它们。让客户能够忽略不同对象层次的变化,客户端可以针对抽象构件编程,无需关心对象层次结构的细节。对象的结构是动态的并
29、且复杂程度不一样,但客户需要一致地处理它们。组合模式模式应用(1)XML文档解析 Carson 31.95 05/01/2001 MSPress WA 组合模式模式应用(2)操作系统中的目录结构是一个树形结构,因此在对文件和文件夹进行操作时可以应用组合模式,例如杀毒软件在查毒或杀毒时,既可以针对一个具体文件,也可以针对一个目录。如果是对目录查毒或杀毒,将递归处理目录中的每一个子目录和文件。组合模式模式应用(3)JDK的AWT/Swing是组合模式在Java类库中的一个典型实际应用。外观模式模式动机Faade(外观)模式例1:传统的医院:病人需要直接跟各个部门打交道门诊门诊门诊门诊挂号挂号挂号挂
30、号划价划价划价划价化验化验化验化验取药取药取药取药Faade(外观)模式人性化的医院接待员代替病人进行挂号、划价等病人只需要和接待员打交道门诊门诊挂号挂号划价划价取药取药接待员接待员医院的门面医院的门面(Facade)Faade(外观)模式例:组建家庭影院Faade(外观)模式欣赏一部电影的辛苦过程:1.拉上窗帘、调暗灯光2.拿出零食3.打开电视机4.打开功放5.打开音响6.打开DVD机7.找出DVD碟片8.把碟片放入DVD机9.开始播放10.Faade(门面)模式家庭影院系统:Faade(门面)模式用OO语言描述看电影的辛苦过程curtain.close();lights.setlight(
31、5);tv.on();dvd.on();dvd.insertdisk(disk);dvd.play();amplifier.on();amplifier.setvolumn(5);Faade(门面)模式缺点客户需要和大量的类打交道操作复杂有时候操作顺序不能颠倒关闭整个系统是不是也是一样的复杂如果家庭影院升级了呢?Faade(门面)模式用一个门面对象简化所有细节外观模式模式动机模式动机引入外观角色之后,引入外观角色之后,用户只需要直接与外观角色交互,用户与子系用户只需要直接与外观角色交互,用户与子系统之间的复杂关系由外观角色来实现统之间的复杂关系由外观角色来实现,从而降低了系统的耦合度,从而降低
32、了系统的耦合度。外观模式模式定义外观模式(Facade):外部与一个子系统的通信必须通过一个统一的外观对象进行,为子系统中的一组接口提供一个一致的界面,外观模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。外观模式又称为门面模式,它是一种对象结构型模式。外观模式模式定义Provide a unified interface to a set of interfaces in a subsystem.Facade defines a higher-level interface that makes the subsystem easier to use.Frequency of us
33、e:high外观模式模式结构外观模式模式结构外观模式包含如下角色:Facade:外观角色SubSystem:子系统角色外观模式模式分析根根据据“单单一一职职责责原原则则”,在在软软件件中中将将一一个个系系统统划划分分为为若若干干个个子子系系统统有有利利于于降降低低整整个个系系统统的的复复杂杂性性,一一个个常常见见的的设设计计目目标标是是使使子子系系统统间间的的通通信信和和相相互互依依赖赖关关系系达达到到最最小小,而而达达到到该该目目标标的的途途径径之之一一就就是是引引入入一一个个外外观观对对象象,它它为为子子系系统统的的访访问问提提供供了了一一个个简简单单而而单单一一的的入入口口。外外观观模模
34、式式也也是是“迪迪米米特特法法则则”的的体体现现,通通过过引引入入一一个个新新的的外外观观类类可可以以降降低低原原有有系系统统的的复复杂杂度度,同同时时降降低低客客户类与子系统类的耦合度户类与子系统类的耦合度。外观模式模式分析模式分析外观模式要求一个子系统的外部与其内部的通信外观模式要求一个子系统的外部与其内部的通信通过通过一个统一的外观对象进行一个统一的外观对象进行,外观类将客户端与子系统,外观类将客户端与子系统的内部复杂性分隔开,使得的内部复杂性分隔开,使得客户端只需要与外观对象客户端只需要与外观对象打交道,而不需要与子系统内部的很多对象打交道打交道,而不需要与子系统内部的很多对象打交道。
35、外观模式的目的在于外观模式的目的在于降低系统的复杂程度降低系统的复杂程度。外观模式从很大程度上外观模式从很大程度上提高了客户端使用的便捷性提高了客户端使用的便捷性,使得客户端无需关心子系统的工作细节,通过外观角使得客户端无需关心子系统的工作细节,通过外观角色即可调用相关功能。色即可调用相关功能。外观模式模式分析典型的外观角色代码:public class Facadeprivate SubSystemA obj1=new SubSystemA();private SubSystemB obj2=new SubSystemB();private SubSystemC obj3=new SubSy
36、stemC();public void method()obj1.method();obj2.method();obj3.method();外观模式外观模式实例与解析实例一:电源总开关现在考察一个电源总开关的例子,以便进一步说明外观模式。为了使用方便,一个电源总开关可以控制四盏灯、一个风扇、一台空调和一台电视机的启动和关闭。通过该电源总开关可以同时控制所有上述电器设备,使用外观模式设计该系统。外观模式外观模式实例与解析实例一:电源总开关外观模式外观模式实例与解析实例一:电源总开关参考代码演示演示演示演示Faade(门面)模式举例:保安系统Faade(门面)模式使用门面模式门面模式设计原则:迪米
37、特法则老子论老子论“圣人之治圣人之治”使民无知使民无知:“是以圣人之治,虚其心,实其腹,是以圣人之治,虚其心,实其腹,弱其志,常使民无知无欲弱其志,常使民无知无欲”老死不相往来老死不相往来:“小国寡民小国寡民.邻国相望,鸡犬邻国相望,鸡犬之声相闻,民至老死,不相往来之声相闻,民至老死,不相往来”软件设计师就是软件系统的统治者软件设计师就是软件系统的统治者应当使得软件的不同对象彼此之间尽量应当使得软件的不同对象彼此之间尽量“老死老死不相往来不相往来”,降低系统维护成本,降低系统维护成本外观模式外观模式实例与解析实例:文件加密某系统需要提供一个文件加密模块,加密流程包括三个操作,分别是读取源文件、
38、加密、保存加密之后的文件。读取文件和保存文件使用流来实现,这三个操作相对独立,其业务代码封装在三个不同的类中。现在需要提供一个统一的加密外观类,用户可以直接使用该加密外观类完成文件的读取、加密和保存三个操作,而不需要与每一个类进行交互,使用外观模式设计该加密模块。外观模式外观模式实例与解析实例二:文件加密外观模式模式优缺点外观模式的优点如下:它对客户屏蔽子系统组件,减少了客户处理的对象数目并使得子系统使用起来更加容易。通过引入外观模式,客户代码将变得很简单,与之关联的对象也很少。它实现了子系统与客户之间的松耦合关系,这使得子系统的组件变化不会影响到调用它的客户类,只需要调整外观类即可。它降低了
39、大型软件系统中的编译依赖性,并简化了系统在不同平台之间的移植过程,因为编译一个子系统一般不需要编译所有其他的子系统。一个子系统的修改对其他子系统没有任何影响,而且子系统内部变化也不会影响到外观对象。它只是提供了一个访问子系统的统一入口,并不影响用户直接使用子系统类。外观模式模式优缺点外观模式的缺点如下:不能很好地限制客户使用子系统类,如果对客户访问子系统类做太多的限制则减少了可变性和灵活性。在不引入新外观类的情况下,增加新的子系统可能需要修改外观类的源代码,违背了“开闭原则”。外观模式模式适用环境在以下情况下可以使用外观模式:当要为一个复杂子系统提供一个简单接口时可以使用外观模式。该接口可以满
40、足大多数用户的需求,而且用户也可以越过外观类直接访问子系统。客户程序与多个子系统之间存在很大的依赖性。引入外观类将子系统与客户以及其他子系统解耦,可以提高子系统的独立性和可移植性。在层次化结构中,可以使用外观模式定义系统中每一层的入口,层与层之间不直接产生联系,而通过外观类建立联系,降低层之间的耦合度。外观模式模式应用(1)JDBC数据库操作 public class JDBCFacade private Connection conn=null;private Statement statement=null;public void open(String driver,String jdb
41、cUrl,String userName,String userPwd).public int executeUpdate(String sql).public ResultSet executeQuery(String sql).public void close().外观模式模式应用(2)Session外观模式是外观模式在Java EE框架中的应用。外观模式模式扩展一个系统有多个外观类在外观模式中,通常只需要一个外观类,并且此外观类只有一个实例,换言之它是一个单例类。在很多情况下为了节约系统资源,一般将外观类设计为单例类。当然这并不意味着在整个系统里只能有一个外观类,在一个系统中可以设计多
42、个外观类,每个外观类都负责和一些特定的子系统交互,向用户提供相应的业务功能。外观模式模式扩展外观模式与迪米特法则 外观模式创造出一个外观对象,将客户端所涉及的属于一个子系统的协作伙伴的数量减到最少,使得客户端与子系统内部的对象的相互作用被外观对象所取代。外观类充当了客户类与子系统类之间的“第三者”,降低了客户类与子系统类之间的耦合度,外观模式就是实现代码重构以便达到“迪米特法则”要求的一个强有力的武器。外观模式模式扩展抽象外观类的引入 外观模式最大的缺点在于违背了“开闭原则”,当增加新的子系统或者移除子系统时需要修改外观类,可以通过引入抽象外观类在一定程度上解决该问题,客户端针对抽象外观类进行
43、编程。对于新的业务需求,不修改原有外观类,而对应增加一个新的具体外观类,由新的具体外观类来关联新的子系统对象,同时通过修改配置文件来达到不修改源代码并更换外观类的目的。外观模式模式扩展抽象外观类的引入 代理模式模式动机模式动机在在某某些些情情况况下下,一一个个客客户户不不想想或或者者不不能能直直接接引引用用一一个个对对象象,此此时时可可以以通通过过一一个个称称之之为为“代代理理”的的第第三三者者来来实实现现间间接接引引用用。代代理理对对象象可可以以在在客客户户端端和和目目标标对对象象之之间间起起到到中中介介的的作作用用,并并且且可可以以通通过过代代理理对对象象去去掉掉客客户户不不能能看看到到的
44、的内内容容和和服务或者添加客户需要的额外服务服务或者添加客户需要的额外服务。代理模式模式动机代理模式模式动机代理模式模式动机通过引入一个新的对象(如小图片和远程代理对象)来实现对真实对象的操作或者将新的对象作为真实对象的一个替身,这种实现机制即为代理模式,通过引入代理对象来间接访问一个对象,这就是代理模式的模式动机。代理模式模式定义代理模式(Proxy Pattern):给某一个对象提供一个代理,并由代理对象控制对原对象的引用。代理模式的英文叫做Proxy或Surrogate,它是一种对象结构型模式。代理模式模式定义 Provide a surrogate or placeholder for
45、 another object to control access to it.Frequency of use:medium high 代理模式模式结构代理模式模式结构代理模式包含如下角色:Subject:抽象主题角色Proxy:代理主题角色RealSubject:真实主题角色代理模式模式分析代理模式示意结构图比较简单,一般可以简化为如下图所示,但是在真实的使用和实现中要复杂很多。代理模式模式分析典型的代理类实现:public class Proxy implements Subjectprivate RealSubject realSubject=new RealSubject();pub
46、lic void preRequest().public void request()preRequest();realSubject.request();postRequest();public void postRequest()代理模式代理模式代理模式实例与解析实例一:论坛权限控制代理 在一个论坛中已注册用户和游客的权限不同,已注册的用户拥有发帖、修改自己的注册信息、修改自己的帖子等功能;而游客只能看到别人发的帖子,没有其他权限。使用代理模式来设计该权限管理模块。在本实例中我们使用代理模式中的保护代理,该代理用于控制对一个对象的访问,可以给不同的用户提供不同级别的使用权限。代理模式代理模
47、式实例与解析实例一:论坛权限控制代理 代理模式代理模式实例与解析实例一:论坛权限控制代理 参考代码演示演示演示演示代理模式代理模式实例与解析实例二:数学运算代理 模拟应用远程代理来访问另外一个应用程序域中的对象,如果在远程实现了加减乘除等运算,在本地需要调用,那么可以考虑在本地设置一个代理。代理模式代理模式实例与解析实例二:数学运算代理 代理模式模式优缺点代理模式的优点如下:代理模式能够协调调用者和被调用者,在一定程度上降低了系统的耦合度。远程代理使得客户端可以访问在远程机器上的对象,远程机器可能具有更好的计算性能与处理速度,可以快速响应并处理客户端请求。虚拟代理通过使用一个小对象来代表一个大
48、对象,可以减少系统资源的消耗,对系统进行优化并提高运行速度。保护代理可以控制对真实对象的使用权限。代理模式模式优缺点代理模式的缺点如下:由于在客户端和真实主题之间增加了代理对象,因此有些类型的代理模式可能会造成请求的处理速度变慢。实现代理模式需要额外的工作,有些代理模式的实现非常复杂。代理模式模式适用环境根据代理模式的使用目的,常见的代理模式有以下几种类型:远程(Remote)代理:为一个位于不同的地址空间的对象提供一个本地的代表对象,这个不同的地址空间可以是在同一台主机中,也可是在另一台主机中,远程代理又叫做大使(Ambassador)。虚拟(Virtual)代理:如果需要创建一个资源消耗较
49、大的对象,先创建一个消耗相对较小的对象来表示,真实对象只在需要时才会被真正创建。Copy-on-Write代理:它是虚拟代理的一种,把复制(克隆)操作延迟到只有在客户端真正需要时才执行。一般来说,对象的深克隆是一个开销较大的操作,Copy-on-Write代理可以让这个操作延迟,只有对象被用到的时候才被克隆。代理模式模式适用环境根据代理模式的使用目的,代理模式有以下几种类型(续):保护(Protect or Access)代理:控制对一个对象的访问,可以给不同的用户提供不同级别的使用权限。缓冲(Cache)代理:为某一个目标操作的结果提供临时的存储空间,以便多个客户端可以共享这些结果。防火墙(
50、Firewall)代理:保护目标不让恶意用户接近。同步化(Synchronization)代理:使几个用户能够同时使用一个对象而没有冲突。智能引用(Smart Reference)代理:当一个对象被引用时,提供一些额外的操作,如将此对象被调用的次数记录下来等。代理模式模式应用(1)Java RMI(Remote Method Invocation,远程方法调用)。代理模式模式应用(2)EJB、Web Service等分布式技术都是代理模式的应用。在EJB中使用了RMI机制,远程服务器中的企业级Bean在本地有一个桩代理,客户端通过桩来调用远程对象中定义的方法,而无需直接与远程对象交互。在EJB