JAVA设计模式之 装饰模式【Decorator Pattern】

一、概述

动态地给一个对象增加一些额外的职责,就增加对象功能来说,装饰模式比生成子类实现更为灵活。装饰模式是一种对象结构型模式。装饰模式是一种用于替代继承的技术,使用对象之间的关联关系取代类之间的继承关系。在装饰模式中引入了装饰类,在装饰类中既可以调用待装饰的原有类的方法,还可以增加新的方法,以扩充原有类的功能。

二、适用场景

装饰原有对象、在不改变原有对象的情况下扩展增强新功能/新特征.。当不能采用继承的方式对系统进行扩展或者采用继承不利于系统扩展和维护时可以使用装饰模式。

三、UML类图

四、参与者

①Component(抽象构件):它是具体构件和抽象装饰类的共同父类,声明了在具体构件中实现的业务方法。

②ConcreteComponent(具体构件):它是抽象构件类的子类,用于定义具体的构件对象(被装饰者),实现了在抽象构件中声明的方法,装饰器可以给它增加额外的职责(方法)。

③Decorator(抽象装饰类):它也是抽象构件类的子类,用于给具体构件增加职责,但是具体职责在其子类中实现。它维护一个指向抽象构件对象的引用,通过该引用可以调用装饰之前构件对象的方法,并通过其子类扩展该方法,以达到装饰的目的。

④ConcreteDecorator(具体装饰类):它是抽象装饰类的子类,负责向构件添加新的职责。每一个具体装饰类都定义了一些新的行为,它可以调用在抽象装饰类中定义的方法,并可以增加新的方法用以扩充对象的行为。

五、用例学习

1、角色:抽象构件 Component.java

/**
 * 设计模式之 装饰模式<br/>
 * 角色:抽象构件<br/>
 * 被装饰的对象抽象类<br/>
 * @author [email protected]
 *
 */
public abstract class Component {

    public abstract void operation();
}

2、角色:具体构件类 ConcreteComponent.java

/**
 * 设计模式之 装饰模式<br/>
 * 角色:具体构件类<br/>
 * 抽象构件类的子类,定义具体的构件对象,也就是具体的被装饰对象<br/>
 * @author  [email protected]
 *
 */
public class ConcreteComponent extends Component {

    @Override
    public void operation() {
        System.out.println("我是具体的构件类(被装饰对象),这是我的原有方法");
    }

}

3、角色:抽象装饰类 Decorator.java

/**
 * 设计模式之 装饰模式<br/>
 * 角色:抽象装饰类<br/>
 * 也是抽象构件类的子类,目的是能够进行多次装饰<br/>
 * 作用:引入抽象构件类, 给具体构件类增加职责,但是具体职责在其子类中实现<br/>
 * @author [email protected]
 *
 */
public class Decorator extends Component {

    // 维持一个对抽象构件对象的引用
    private Component component;

    // 注入一个抽象构件类型的对象
    public Decorator(Component component) {
        this.component = component;
    }

    @Override
    public void operation() {
        // 调用原有业务方法
        component.operation();
    }

}

4、角色:具体装饰类 ConcreteDecoratorA.java

/**
 * 设计模式之 装饰模式<br/>
 * 角色:具体装饰类<br/>
 * 向构件添加新的具体的职责、扩充原有对象的行为
 * @author [email protected]
 *
 */
public class ConcreteDecoratorA extends Decorator {

    public ConcreteDecoratorA(Component component) {
        super(component);
    }

    @Override
    public void operation() {
        super.operation();
        // 调用增强业务方法,对原有对象进行装饰、扩展、增强
        addedBehavior();
    }

    private void addedBehavior(){
        System.out.println("我是具体的装饰类A,我可以增强原有对象方法");
    }

}

5、角色:具体装饰类 ConcreteDecoratorB.java

/**
 * 设计模式之 装饰模式<br/>
 * 角色:具体装饰类<br/>
 * 向构件添加新的具体的职责、扩充原有对象的行为
 * @author  [email protected]
 *
 */
public class ConcreteDecoratorB extends Decorator {

    public ConcreteDecoratorB(Component component) {
        super(component);
    }

    @Override
    public void operation() {
        super.operation();
        // 调用增强业务方法,对原有对象进行装饰、扩展、增强
        addedOtherBehavior();
    }

    private void addedOtherBehavior(){
        System.out.println("我是具体的装饰类B,我也可以增强原有对象方法");
    }
}

6、客户端测试类 Client.java

public class Client {

    public static void main(String[] args) {
        Component component,decoratorA;
        component = new ConcreteComponent();

        decoratorA = new ConcreteDecoratorA(component);
        // 对原有具体构件类ConcreteComponent的增强行为
        decoratorA.operation();

        System.out.println("---------------------------\n");

        System.out.println("---对原有构件对象进行 decoratorA、decoratorB 二次装饰---");
        // 如果需要对原有构件对象装饰后的decoratorA对象上进行再次装饰
        Component decoratorB;
        decoratorB = new ConcreteDecoratorB(decoratorA);
        decoratorB.operation();
    }

}

7、运行结果:

我是具体的构件类(被装饰对象),这是我的原有方法
我是具体的装饰类A,我可以增强原有对象方法
---------------------------

---对原有构件对象进行 decoratorA、decoratorB 二次装饰---
我是具体的构件类(被装饰对象),这是我的原有方法
我是具体的装饰类A,我可以增强原有对象方法
我是具体的装饰类B,我也可以增强原有对象方法

六、其他

时间: 2024-10-10 13:45:38

JAVA设计模式之 装饰模式【Decorator Pattern】的相关文章

Java设计模式之适配器模式(Adapter Pattern)

Adapter Pattern的作用是在不改变功能的前提下转换接口.Adapter分为两类,一类是Object Adapter, 另一类是Class Adapter.由于Class Adapter的实现需要用到多继承,而Java不支持多继承,所以这里只关注Object Adapter. 在JDK1.5之前是没有 java.util.Iterator 接口的,java.util.Enumeration 接口起着 Iterator 的作用.那么如果我们需要维护一些年代比较久远的代码,可能就会面临着没

Java设计模式之观察者模式(Observer Pattern)

Observer Pattern 是一种常用的设计模式,它是一种事件监听模型.该模式有两个角色,一个是Subject, 另一个是Observer.Subject 保存有多个Observer的引用,一旦特定的事件发生,Subject会通知它所有的Observer,Observer得到该通知后执行相关程序逻辑.其中,Observer只有先向Subject注册后才能被Subject知晓.这就像订报纸,只有我们向出版社提出订报的申请,出版社才会把我们列入订阅者名单,然后每当新报纸印好时,出版社会通知订阅

[设计模式]&lt;4&gt;. C++与装饰模式(decorator pattern)

原文地址: http://www.cnblogs.com/hebaichuanyeah/p/5612028.html 装饰模式是指,动态的为一个类增加职责(相对于继承). 截自<设计模式>装饰者的UML图 举个栗子,

设计模式-装饰模式(Decorator Pattern)

Attach additional responsibilities to an object dynamically keeping the same interface.Decorators provide a flexible alternative to subclassing for extending functionality.(动态地给一个对象添加一些额外的职责.就增加功能来说,装饰模式相比生成子类更为灵活.) 装饰模式有四个角色:1.Component抽象构件Component

浅谈JAVA设计模式之——装饰模式(Decorator)

转载请注明出处:http://blog.csdn.net/l1028386804/article/details/45464445 一.概述 动态地给一个对象添加一些额外的职责.就增加功能来说,Decorator模式相比生成子类更为灵活. 二.适用性 1.在不影响其他对象的情况下,以动态.透明的方式给单个对象添加职责. 2.处理那些可以撤消的职责. 3.当不能采用生成子类的方法进行扩充时. 三.参与者 1.Component 定义一个对象接口,可以给这些对象动态地添加职责. 2.Concrete

设计模式实现C++ --装饰模式Decorator Pattern

定义:动态地将责任附加到对象上.若要扩展功能,装饰者提供了比继承更有弹性的替代方案. 类图: Component:定义一个对接接口,可以给这些对象动态的添加职责: ConcreteComponent:定义一个具体的对象,也可以给对象添加一些职责: Decorator:装饰抽象类,继承了Component,从外类来扩展Component类的功能,对于Component来说无需知道Decorator的存在: ConcreteDecorator:具体的装饰对象,起到给Component添加职责的功能:

装饰模式(Decorator pattern)

装饰模式又名包装(Wrapper)模式.装饰模式以对客户端透明的方式扩展对象的功能,是继承关系的一个替代方案. 装饰模式的结构 装饰模式以对客户透明的方式动态地给一个对象附加上更多的责任.换言之,客户端并不会觉得对象在装饰前和装饰后有什么不同.装饰模式可以在不使用创造更多子类的情况下,将对象的功能加以扩展.装饰模式的类图如下: 在装饰模式中的角色有: 抽象构件(Component)角色:给出一个抽象组件接口,以规范准备接收附加责任的对象,即可以给这些对象动态地添加职责. 具体构件(Concret

JAVA设计模式:装饰模式

前面我们学习了代理模式: 代理模式主要使用了java的多态,干活的是被代理类,代理类主要是接活,你让我干活,好,我交给幕后的类去干,你满意就成,那怎么知道被代理类能不能干呢?同根就成,大家知根知底,你能做啥,我能做啥都清楚得很,同样一个接口. 本次我们学习下装饰模式: 装饰模式又称为包装模式,装饰模式以对客户端透明的方式扩展对象功能,相对于代理而言,代理是不让客户端知道真实对象的信息,装饰模式是基层关系的一个替代方案. 装饰模式是采用对客户端透明的方式动态的给一个对象添加了更多职责,对于原来被装

Java设计模式模式观测(Observer Pattern)

Observer Pattern 设计模式通常用于.这是一个事件侦听器模型. 该模型有两个作用,一个是Subject, 有一个Observer.Subject 保存多个Observer参考,一旦一个特定的事件发生.Subject它会通知所有Observer.Observer得到该通知后运行相关程序逻辑. 当中,Observer仅仅有先向Subject注冊后才干被Subject知晓.这就像订报纸,仅仅有我们向出版社提出订报的申请,出版社才会把我们列入订阅者名单.然后每当新报纸印好时,出版社会通知订