软件设计模式之装饰模式

软件设计模式

软件设计模式的概念:
软件设计模式,又称设计模式,是一套被反复使用、多数人知晓的、经过分类编目的、代码设计经验的总结。它描述了在软件设计过程中的一些不断重复发生的问题,以及该问题的解决方案。也就是说,它是解决特定问题的一系列套路,是前辈们的代码设计经验的总结,具有一定的普遍性,可以反复使用。
其目的是为了提高代码的可重用性、代码的可读性和代码的可靠性。

学习设计模式的意义:
设计模式的本质是面向对象设计原则的实际运用,是对类的封装性、继承性和多态性以及类的关联关系和组合关系的充分理解。正确使用设计模式具有以下优点:
(1)可以提高程序员的思维能力、编程能力和设计能力;
(2)使程序设计更加标准化、代码编制更加工程化,使软件开发效率大大提高,从而缩短软件的开发周期;
(3)使设计的代码可重用性高、可读性强、可靠性高、灵活性好、可维护性强。

软件设计模式的基本要素:
软件设计模式使人们可以更加简单方便地复用成功的设计和体系结构,它通常包含以下几个基本要素:模式名称、别名、动机、问题、解决方案、效果、结构、模式角色、合作关系、实现方法、适用性、已知应用、例程、模式扩展和相关模式等,其中最关键的元素包括以下4个主要部分。
(1)模式名称:
每一个模式都有自己的名字,通常用一两个词来描述,可以根据模式的问题、特点、解决方案、功能和效果来命名。模式名称(PatternName)有助于我们理解和记忆该模式,也方便我们来讨论自己的设计。
(2)问题:
问题(Problem)描述了该模式的应用环境,即何时使用该模式。它解释了设计问题和问题存在的前因后果,以及必须满足的一系列先决条件。
(3)解决方案:
模式问题的解决方案(Solution)包括设计的组成成分、他们之间的相互关系及各自的职责和协作方式。因为模式就像一个模板,可应用与多种不同的场合,所以解决方案并不描述一个特定而具体的设计或实现,而是提供设计问题的抽象描述和怎样用一个具有一般意义的元素组合(类或对象的组合)来解决这个问题。
(4)效果:
描述了模式的应用效果以及使用该模式应该权衡的问题,即模式的优缺点。主要是对时间和空间的衡量,以及该模式对系统的灵活性、扩充性、可移植性的影响,也考虑其实现问题。显式地列出这些效果(Consequence)对理解和评价这些模式有很大的帮助。

装饰模式

定义:
装饰模式是的是在不必改变原类文件和使用继承的情况下,动态地扩展一个对象的功能。它是通过创建一个包装对象,也就是装饰来包裹真实的对象。

特点:
1、装饰对象和真实对象有相同的接口。这样客户端对象就能以和真是对象相同的方式和装饰对象交互;
2、装饰对象包含一个真实对象的引用;
3、装饰对象接受所有来自客户端的请求。它把这些请求转发给真实的对象;
4、装饰对象可以在转发这些请求以前或以后增加一些附加功能。

装饰者模式中的各组件:
1、抽象构件角色:给出一个抽象接口,以规范准备接受附加责任的对象;
2、具体构建角色:定义一个将要接受附加责任的类;
3、装饰角色:持有一个构件对象的实例,并定义一个与抽象构件接口一致的接口;
4、具体装饰角色:负责给构件对象“贴上”附加的责任。

使用场景:
1、需要扩展一个类的功能,或给一个类添加附加职责;
2、需要动态的给一个对象添加功能,这些功能可以再动态的撤销;
3、需要增加由一些基本功能的排列组合二产生的非常大量的功能,从而使继承关系变的不现实;
4、当不能采用生成子类的方法进行扩充时。一种情况是,可能有大量独立的扩展,为支持每一种组合将产生大量的子类,使得子类数目呈爆炸性增长。另一种情况可能是因为类定义被隐藏,或类定义不能用于生成子类。

优点:
1、Decorator模式与继承关系的目的都是要扩展对象的功能,但是Decorator可以提供比继承更多的灵活性;
2、通过使用不同的具体装饰类以及这些装饰类的排列组合,设计师可以创造出很多不同行为的组合;
3、符合开闭原则。

缺点
1、这种比继承更加灵活机动的特性,也同事意味着更多的复杂性;
2、装饰着模式会导致设计中出现许多小类,如果过度使用,会使程序变得很复杂;
3、装饰模式是针对抽象组件(Component)类型编程。

相关设计模式:
1、装饰者模式:关注再一个对象上动态添加方法;
2、代理模式:关注再对代理对象的控制访问,可以对客户隐藏被代理类的信息
装饰着模式和适配器模式都叫包装模式

关于新职责:适配器也可以在转换时增加新的职责,但主要目的不在此。装饰者模式主要是给被装饰者增加新职责的。

关于原接口:适配器模式是用新接口来调用原接口,原接口对新系统是不可见或者说不可用的。装饰者模式原封不动的使用原接口,系统对装饰的对象也通过原接口来完成使用。(增加新接口的装饰者模式可以认为是其变种–“半透明”装饰者)

关于其包裹的对象:适配器是知道被适配者的详细情况的(就是那个类或那个接口)。装饰者只知道其接口是什么,至于其具体类型(是基类还是其他派生类)只有在运行期间才知道。

参考文献:
https://zhuanlan.zhihu.com/p/73444030
http://c.biancheng.net/view/1317.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值