//---------------------------15/04/17----------------------------

//Decorator 装饰模式----对象结构型模式

/*

1:意图:

动态地给一个对象添加额外的职业,就增加功能来说,Decorator模式相比生成子类更为灵活。

2:别名:

包装器(Wrapper)

3:动机:

4:适用性:

1>在不影响其他对象的情况下,以动态、透明的方式给单个对象添加职责。

2>处理那些可以撤销的职责。

3>当不能采用生成子类的方法进行扩充时:

1)可能有大量独立的扩展,为支持每一种组合将产生大量的子类。

2)类定义被隐藏,或类定义不能用于生成子类。

5:结构:

Component:<------------------

Operation                   |

|                       |

|                       |

------------------              |

|                |              |

ConcreteComponent:      Decorator:      |

Operation()             component--------

Operation()

{ component->Operation() }

|

|

--------------------

|                  |

ConcreteDecoratorA: ConcreteDecoratorB:

Operation()         Operatione()

addedState()        {   Decorator::Operation();

AddedBehavior();        }

AddedBehavior()

6:参与者:

1>Component

定义一个对象接口,可以给这些对象动态地添加职责。

2>ConcreteComponent

定义一个对象,可以给这个对象添加职责。

3>Decorator

维持一个指向Component对象的指针,并定义一个与Component接口一致的接口。

4>ConcreteDecorator

向组件添加职责。

7:协作:

Decorator将请求转发给它的Component对象,并有可能在转发请求前后执行一些附加的动作。

8:效果:

1>优点:

1)比静态继承更灵活。

Decorator模式提供了更加灵活的向对象添加职责的方式,在运行时刻添加和删除职责。

相比于使用继承,Decorator模式可以很容易地重复添加一个特性,而重复继承很容易出错。

2)避免在层次结构高层的类有太多特征。

Decorator模式提供了一种“即用即付”的方法来添加职责。可以对一个简单的类扩展出复杂的

功能。

2>缺点:

1)Decorator和它的Component不一样。

被装饰了的组件和没装饰时是有差别的,因此,使用装饰时不应该依赖对象标识。

装饰后,在别的对象看来,就是Decorator类了,而不是ConcreteCompnent类了

2)有许多小对象。

采用Decorator模式进行系统设计往往会产生许多看上去类似的小对象,这些对象仅仅在他们相互

连接的方式上有所不同,而不是它们的类或是他们的属性值有所不同。所以这些系统很难学习和排错。

9:实现:

1>接口的一致性:

装饰对象的接口必须与它所装饰的Component的接口是一致的,因此所有的ConcreteDecorator类必须

有一个公共的父类。

2>省略抽象的Decorator类:

当你仅需要添加一个职责时,没有必要定义抽象的Decorator类。

3>保持Component类的简单性:

为了接口的一致性,组件和装饰都必须继承自Component类,所以保持这个类的简单性很重要。

也就是把这个类设计目的集中于接口设计,而不是存储数据。

4>改变对象外壳与改变对象内核:

可以把Decorator类当作是一个对象的外壳,添加Decorator类可以改变一个对象的行为,但是当

Component类很庞大时,添加一个Decorator类代价就显得很大。所以可以选择使用另外一种模式:

Strategy模式,组件可以将一些行为转发给一个独立的策略对象,通过改变策略对象,就可以达到

改变或扩充组件的功能。

10:代码示例:                                                                            */

//Component类,提供了接口

class VisualComponent

{

public:

VisualComponent();

virtual
void Draw();

virtual
void Resize();

...

};

//abstract Decorator类

class Decorator :public VisualComponent

{

public:

Decorator(VisualComponent*);

virtual
void Draw();

virtual
void Resize();

...

private:

VisualComponent* _component;

};

void Decorator::Draw()

{

_component->Draw();

}

void Decorator::Resize()

{

_component->Resize();

}

//ConcreteDecorator类
在自己的Draw()中添加了要添加的职责--绘制边框

class BorderDecorator :public Decorator

{

public:

BorderDecorator(VisualComponent*,int borderWidth);

virtual
void Draw();

private:

void DrawBorder(int);

private:

int _width;

};

void BorderDecorator::Draw()

{

Decorator::Draw();

DrawBorder(_width);

}

//这里的SetContents以一个Component指针为参数,来进行一些操作,

//通过装饰就可以传入一个装饰过的类

void Window::SetContents(VisualComponent* contents)

{

...

}

Window* window =new Window;

//未经装饰的类,TextView是继承自Component类的ConcreteComponent类

TextView* textView =new TextView;

//它可以被这样传入

window->SetContents(textView);

//也可以通过装饰来传入,这样装饰就增加了起码两个Component大小的内存了,所以

//如果Compnent如果很庞大的话,使用代价会很高。

window->SetContents());

//再考虑一个问题,如果深度很深的话,实现起来效率也会下降。

//何谓深度,就是装饰了很多很多次,这里的调用其实就是通过指针不断访问下一个对象调用Draw(),就和链表一样,

//如果深度很深,那么就像遍历链表一样。

//这时可以考虑实现中最后一点说的,使用strategy模式。

设计模式 笔记 装饰模式 Decorator的更多相关文章

  1. 乐在其中设计模式(C#) - 装饰模式(Decorator Pattern)

    原文:乐在其中设计模式(C#) - 装饰模式(Decorator Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 装饰模式(Decorator Pattern) 作者:weba ...

  2. 二十四种设计模式:装饰模式(Decorator Pattern)

    装饰模式(Decorator Pattern) 介绍动态地给一个对象添加一些额外的职责.就扩展功能而言,它比生成子类方式更为灵活.示例有一个Message实体类,某个对象对它的操作有Insert()和 ...

  3. 设计模式-09装饰模式(Decorator Pattern)

    1.模式动机 一般有两种方式可以实现给一个类或对象增加行为: 继承机制:使用继承机制是给现有类添加功能的一种有效途径,通过继承一个现有类可以使得子类在拥有自身方法的同时还拥有父类的方法.但是这种方法是 ...

  4. 设计模式之装饰模式(Decorator)摘录

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/fengbingchun/article/details/29237955 23种GOF设计模式一般分 ...

  5. 结构型设计模式之装饰模式(Decorator)

    结构 意图 动态地给一个对象添加一些额外的职责.就增加功能来说,D e c o r a t o r 模式相比生成子类更为灵活. 适用性 在不影响其他对象的情况下,以动态.透明的方式给单个对象添加职责. ...

  6. 设计模式之装饰模式(Decorator)

    装饰模式原理:给对象增加特性,这种特性是一种累加的效果 代码如下 #include <iostream> #include <string> #include <list ...

  7. 【设计模式】—— 装饰模式Decorator

    前言:[模式总览]——————————by xingoo 模式意图 在不改变原来类的情况下,进行扩展. 动态的给对象增加一个业务功能,就功能来说,比生成子类更方便. 应用场景 1 在不生成子类的情况下 ...

  8. Netty学习-IO体系架构系统回顾 & 装饰模式Decorator的具体使用

    Netty学习-IO体系架构系统回顾 IO和NIO的学习 NIO - 1.4 开始出的 在网络应用框架中,NIO得到了大量的使用,特别是netty里面 前提:对IO及其了解 对IO的总结和回顾 理解J ...

  9. 设计模式系列之装饰模式(Decorator Pattern)——扩展系统功能

    说明:设计模式系列文章是读刘伟所著<设计模式的艺术之道(软件开发人员内功修炼之道)>一书的阅读笔记.个人感觉这本书讲的不错,有兴趣推荐读一读.详细内容也可以看看此书作者的博客https:/ ...

随机推荐

  1. post请求的四种数据格式

    1.application/json:这是最常见的 json 格式:{"input1":"xxx","input2":"ooo&q ...

  2. Java 基本数据类型 && 位运算

    1. Java基本数据类型 1.1 数据类型示意图 类型 字节数 范围 byte 1 -128~127 short 2 -32768~32767 int 4 -231~231-1 long 8 -26 ...

  3. Javaweb学习(三):Servlet程序

    好了,既然开发环境已经配置好了.那么我们首先要搞定得便是servlet了,至于为什么不先去研究jsp,这是因为jsp与servlet本就是一体两面,jsp其本身经过编译.载入.转化等步骤最终会成为se ...

  4. jquery ajax 设置请求头header 参数

    $.ajax( { url:'http://127.0.0.1:30080/api-a/quasiCustom/selectCustomList', type:'post', dateType:'js ...

  5. Ecstore Nginx Rewrite(去掉链接中的index.php) ECSTORE 伪静态

    一.修改 nginx.conf文件,添加如下代码: if ($request_uri ~ (.+?\.php)(|/.+)$ ){ break; } if (!-e $request_filename ...

  6. 部署weblogic遇到的问题总结

    myeclipse开发的项目,运行在tomcat7上完全正常.部署到weblogic10上就出现了问题,现把问题记录一下: 1.找不到javax/servlet/jsp/jstl/core/Condi ...

  7. [工具]StarUML

    前些日子整理文档,需要补充程序结构流程图,一直没有想到怎么样能够清晰直观描述清楚现在的解决方法,直到我知道了 UML 语言.最早对于 UML 的了解也只是停留在一本书上,他们开发使用 UML 分解任务 ...

  8. JavaSript模块规范 - AMD规范与CMD规范介绍[转]

    原文地址:http://blog.chinaunix.net/uid-26672038-id-4112229.html JavaSript模块化 在了解AMD,CMD规范前,还是需要先来简单地了解下什 ...

  9. How to display values with in piechart using Jfreechart(values in sector )

    I am using Jfreechart to create pie charts. Values are displayed outside pie chart as labels. I want ...

  10. FreeChart柱状图中如何取消柱子的倒影

    JFreeChart柱状图中如何取消柱子的倒影,让柱子显示为一个平面图 Render 该怎么设置呢? 问题补充:已解决 intervalBarRender.setShadowVisible(false ...