您的位置:首页 > 其它

Design Pattern - 装饰模式

2013-02-05 16:47 225 查看

装饰模式

动态 地给一个对象 添加一些额外的职责 。就增加功能来说,Decorator模式相比生成子类更为灵活。
对于对象功能的扩展, 面向对象一般通过继承来解决, 但这种方式缺乏灵活性, 而且随意定义子类容易导致类层次结构过快膨胀.
场景, 当类的核心职责和主要行为没有发生变化, 仅仅需要动态对类对象添加一些装饰性的功能, 比如给人穿衣服......
如下图所示, 只是为图画换换边框, 这种改动只需要使用下面介绍的装饰模式.



装饰模式实现, 如下代码,

class Component    //核心类
{
void Operation();
}

class Decorator: Component //装饰类, 必须继承自核心类, 第一是要保持接口一致, 更重要的是, 这样可以嵌套装饰
{
protected Component com; //核心类对象(引用, 需多态)
void setComponent (Component com) {this.com = com}
void Operation()
{
com.Operation() //这儿除了调用核心类的功能, 可以任意添加装饰性功能
}
}


客户代码使用,

com = new Component()
dec = new Decorator()
dec.setComponent(com)
dec.Operation() //这个Operation就是经过装饰的


装饰模式如下图, 我们可以创建一个抽象Decorator类, 然后根据需要创建许多的ConcreteDecroator类. 而Decorator类可以装饰任意Component类.

而且Decorator类只是对核心类对象进行动态装饰, 不会影响到核心类本身, 所以可以任意装饰, 加成员变量, 调用其他函数, 如ConcreteDecroatorA, ConcreteDecroatorB.

且Decorator类本身也是Component类, 所以可以嵌套装饰, 非常的强大,

com = new Component()
dec_a = new ConcreteDecroatorA()
dec_b = new ConcreteDecroatorB()
dec_c = new ConcreteDecroatorC()
dec_a.setComponent(com)
dec_b.setComponent(dec_a)
dec_c.setComponent(dec_b)
dec_c.Operation() //这个Operation就是经过多次装饰的






装饰模式的好处,

首先, 有效的将类的核心职能和装饰功能区分开了, 动态装饰完全不会影响核心类 便于维护, 可复用性强.

其次, 有效的解决了子类的快速膨胀的问题, 如果单纯用继承来解决问题, 不但对于装饰A,B,......各需要子类, 而且对于各种装饰的组合也需要创建子类. 当装饰种类很多时, 可想而知那会创建非常多的子类. 而使用装饰模式, 只需要对每个装饰生成子类, 而装饰的组合和搭配只需要嵌套使用装饰模式就可以达成.

这个模式还是很实用, 很强大的, 可以用于很多场景......

具体实用例子参考, /article/4893360.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: