面向对象UML设计模式.ppt

  1. 1、本文档共63页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

设计模式

DesignPatterns

设计模式分类创立型模式结构型模式行为型模式

创立型模式创立型模式的目的使系统独立于如何创立、组合和表示对象。隐藏了这些类的实例是如何被创立和放在一起的AbstractFactoryBuilderFactoryMethodPrototypeSingleton

创立型模式AbstractFactory〔数据库的替换〕意图提供一个创立一系列相关或相互依赖对象的接口,而无需指定它们具体的类。适用性一个系统要独立于它的产品的创立、组合和表示时。一个系统要用多个产品系列中的一个来配置时。要强调一系列相关的产品对象的设计以便进行联合使用时。提供一个产品类库,而只想显示它们的接口而不是实现时。

?

AbstractFactory模式的结构

创立型模式AbstractFactory

FactoryMethod〔运算〕意图定义一个用于创立对象的接口,让子类决定实例化哪一个类。FactoryMethod使一个类的实例化延迟到其子类。

当系统扩展需要添加新的产品对象时,仅仅需要添加一个具体对象以及一个具体工厂对象,原有工厂对象不需要进行任何修改,也不需要修改客户端,很好的符合了“开放-封闭〞原那么

创立型模式Builder〔建造小人〕意图将一个复杂对象的构建与它的表示别离,使得同样的构建过程可以创立不同的表示。适用性当创立复杂对象的算法应该独立于该对象的组成局部以及它们的装配方式时。当构造过程必须允许被构造的对象有不同的表示时。效果可以改变一个产品的内部表示。将构造代码和表示代码分开。可以对构造过程进行更精细的控制。

创立型模式Prototype〔简历复印〕意图用原型实例指定创立对象的种类,并且通过拷贝这些原型创立新的对象。

创立型模式Prototype〔原型〕效果可在运行时刻增加和删除产品。可以通过改变值来指定新产品。可以通过改变结构来指定新对象。减少了子类的构造。可以用类动态配置应用。实现使用一个原型管理器;实现克隆操作〔浅拷贝和深拷贝〕;初始化克隆对象;

创立型模式Singleton〔打印机〕意图保证一个类仅有一个实例,并提供一个访问它的全局访问点。适用性在一个系统要求一个类只有一个实例时才应当使用单例模式

创立型模式Singleton

结构型模式结构型模式的目的结构型模式涉及到如何组合类和对象以获得更大的结构。AdapterBridgeCompositeDecoratorFacadeFlyweightProxy

结构型模式Adapter〔NBA翻译〕意图将一个类的接口转换成客户希望的另外一个接口,使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。适用性你想使用一个已经存在的类,而它的接口不符合你的需求。你想创立一个可以复用的类,该类可以与其他不相关的类或不可预见的类〔即那些接口可能不一定兼容的类〕协同工作。〔仅适用于对象Adapter〕你想使用一些已经存在的子类,但是不可能对每一个都进行子类化以匹配它们的接口。对象适配器可以适配它的父类接口。

结构型模式Adapter

结构型模式Bridge〔软件〕意图将抽象局部与它的实现局部别离,使它们都可以独立地变化。适用性不希望在抽象和它的实现局部之间有一个固定的绑定关系。类的抽象以及它的实现都应该可以通过生成子类的方法加以扩充。对一个抽象的实现局部的修改应对客户不产生影响,即客户的代码不必重新编译。效果别离了接口及其实现局部。提高了可扩充性。实现了细节对客户透明。

结构型模式Bridge〔桥接〕

结构型模式Composite〔公司与分公司〕意图将对象组合成树形结构以表示“局部-整体〞的层次结构。Composite使得用户对单个对象和组合对象的使用具有一致性。适用性你想表示对象的局部-整体层次结构。你希望用户忽略组合对象与单个对象的不同,用户将统一地使用组合结构中的所有对象。

结构型模式Composite〔组合〕

结构型模式Decorator〔小菜扮靓〕意图动态地给一个对象添加一些额外的职责。就增加功能来说,Decorator模式相比生成子类更为灵活。适用性在不影响其他对象的情况下,以动态、透明的方式给单个对象添加职责。处理那些可以撤消的职责。当不能采用生成子类的方法进行扩充时。一种情况是,可能有大量独立的扩展,为支持每一种组合将产生大量的子类,使得子类数目呈爆炸性增长。另一种情况可能是因为类定义被隐藏,或类定义不能用于生成子类。

结构型模式Decorator〔装饰〕

结构型模式Facade〔投资基金〕意图为子系统中的一组接口提供一个一致的界面,Facade模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。适用性为一个复杂子系统提供一个简单接口。当客户程序与抽象类的实现局部之间存在着很大的依赖性时,引入Fa

文档评论(0)

199****4744 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:7002121022000045

1亿VIP精品文档

相关文档