一、装饰模式的定义
装饰模式是一种比较常见的模式,其定义如下:Attach additional responsibilities to an object dynamically keeping the same interface.Decorators provide a flexible alternative to subclassing for extending functionality.(动态地给一个对象添加额外的职责。就增加功能来说,装饰模式相比生成子类更为灵活)
装饰模式的通用类图如图:
Component抽象构件:Component是一个接口或者是抽象类,就是定义我们最核心的对象,也就是最原始的对象
ConcreteComponent具体构件:ConcreteComponent是最核心、最原始、最基本的接口或抽象类的实现,你要装饰的就是它
Decorator装饰角色:一般一个抽象类,做什么用呢?实现接口或抽象方法,这里面不一定有抽象的方法,在它的属性里必然有一个private变量指向Component抽象构件
具体装饰角色:ConcreteDecoratorA和ConcreteDecoratorB是两个具体的装饰类,你要把你最核心的、最原始的、最基本的东西装饰成其他东西
抽象构件代码:
public abstract class Component { //抽象的方法 public abstract void operate(); }
具体构件代码:
public class ConcreteComponent extends Component { @Override public void operate() { System.out.println("do somthing"); } }
抽象装饰者:
public abstract class Decorator extends Component { private Component component = null; public Decorator(Component component) { this.component = component; } @Override public void operate() { this.component.operate(); } }
具体装饰类:
public class ConcreteDecorator1 extends Decorator { public ConcreteDecorator1(Component component) { super(component); } private void method1() { System.out.println("method1 修饰"); } @Override public void operate() { this.method1(); super.operate(); } } public class ConcreteDecorator2 extends Decorator { public ConcreteDecorator2(Component component) { super(component); } private void method2() { System.out.println("method2 修饰"); } @Override public void operate() { this.method2(); super.operate(); } }
场景类:
public class Client { public static void main(String args[]) { Component component = new ConcreteComponent(); //第一次修饰 component = new ConcreteDecorator1(component); //第二次修饰 component = new ConcreteDecorator2(component); //修饰后运行 component.operate(); } }
二、装饰的优缺点和使用场景
优点:
装饰类与被装饰类可以独立发展,而不会相互耦合。换句话说,Component类无需知道Decorator类,Decorator类是从外部扩展Component类的功能,而Decorator也不用知道具体的构件
装饰模式是继承关系的一个替代方案。我们看装饰类Decorator,不管装饰多少层,返回的还是Component,实现的还是is-a的关系
装饰模式可以动态地扩展一个实现类的功能
缺点:
对于装饰模式记住一点就够了:多层的装饰是比较复杂的,就像剥洋葱,剥到了最后才发现是最里层的装饰出现了问题,因此尽量减少装饰类的数量,以便降低系统的复杂度。
使用场景:
需要扩展一个累的功能,或者给一个类增加附加功能
需要动态地给一个对象增加功能,这些功能可以再动态的撤销
需要为一批兄弟累进行改装或假装功能,当然首选装饰模式
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍java设计模式学习之装饰模式,包括了java设计模式学习之装饰模式的使用技巧和注意事项,需要的朋友参考一下 装饰模式:动态的给一个对象添加一些额外的职责,就增加功能来说,装饰模式比生成子类更加灵活。 优点:装饰类和被装饰类可以独立发展,不会相互耦合,装饰模式是继承的一个替代模式,装饰模式可以动态扩展一个实现类的功能。 缺点:多层装饰比较复杂。 实例:给一个人配置穿衣 1:代码结构图
介绍 装饰者提供比继承更有弹性的替代方案。 装饰者用用于包装同接口的对象,不仅允许你向方法添加行为,而且还可以将方法设置成原始对象调用(例如装饰者的构造函数)。 装饰者用于通过重载方法的形式添加新功能,该模式可以在被装饰者前面或者后面加上自己的行为以达到特定的目的。 正文 那么装饰者模式有什么好处呢?前面说了,装饰者是一种实现继承的替代方案。当脚本运行时,在子类中增加行为会影响原有类所有的实例,而
本文向大家介绍Java设计模式之装饰模式(Decorator模式)介绍,包括了Java设计模式之装饰模式(Decorator模式)介绍的使用技巧和注意事项,需要的朋友参考一下 Decorator常被翻译成"装饰",我觉得翻译成"油漆工"更形象点,油漆工(decorator)是用来刷油漆的,那么被刷油漆的对象我们称decoratee。这两种实体在Decorator模式中是必须的。 Decorator
本文向大家介绍javascript设计模式之装饰者模式,包括了javascript设计模式之装饰者模式的使用技巧和注意事项,需要的朋友参考一下 在js函数开发中,想要为现有函数添加与现有功能无关的新功能时,按普通思路肯定是在现有函数中添加新功能的代码。这并不能说错,但因为函数中的这两块代码其实并无关联,后期维护成本会明显增大,也会造成函数臃肿。 比较好的办法就是采用装饰器模式。在保持现有函数及其内
装饰(Decorator) Intent 为对象动态添加功能。 Class Diagram 装饰者(Decorator)和具体组件(ConcreteComponent)都继承自组件(Component),具体组件的方法实现不需要依赖于其它对象,而装饰者组合了一个组件,这样它可以装饰其它装饰者或者具体组件。所谓装饰,就是把这个装饰者套在被装饰者之上,从而动态扩展被装饰者的功能。装饰者的方法有一部分是
本文向大家介绍java设计模式之外观模式学习笔记,包括了java设计模式之外观模式学习笔记的使用技巧和注意事项,需要的朋友参考一下 外观模式: 又称门面模式: 外观Facade为子系统的一组接口提供一个一致界面,使得这组子系统易于使用(通过引入一个新的外观角色降低原系统复杂度,同时降低客户类与子系统的耦合度). 图片来源: 设计模式: 可复用面向对象软件的基础. 实现 案例需求: 租房 有过自己找
本文向大家介绍JavaScript设计模式之装饰者模式介绍,包括了JavaScript设计模式之装饰者模式介绍的使用技巧和注意事项,需要的朋友参考一下 装饰者模式说明 说明:通一个类来动态的对另一个类的功能对象进行前或后的修饰,给它辅加一些额外的功能; 这是对一个类对象功能的装饰,装饰的类跟被装饰的类,要求拥有相同的访问接口方法(功能),这在动态面向对象类里,一般以实现同一个接口(interfac
本文向大家介绍Python设计模式之装饰模式实例详解,包括了Python设计模式之装饰模式实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Python设计模式之装饰模式。分享给大家供大家参考,具体如下: 装饰模式(Decorator Pattern):动态的给一个对象添加一些额外的职责,就增加功能来说,装饰模式比生成子类更为灵活. 下面是一个给人穿衣服的过程,使用装饰模式: 运行结