JavaDay07装饰模式

装饰模式(Decorate)是指在不必改变原类文件和使用继承的情况下,动态的扩展一个类的功能。它是通过创建一个包装对象,也就是装饰来包裹真实的对象。包裹的方式一般是将原来的对象作为装饰类构造方法的参数,但是在不需要用到新功能的地方,它可以直接调用原来的类中的方法。装饰类必须和原来的类具有相同的接口。
装饰模式中的角色如下:

1.抽象构件角色(Component)

抽象构件角色给出一个抽象接口,以规范准备接收附加责任的对象。

2.具体构件角色(Concrete Component)

定义一个将要接收附加责任的类。

3.装饰角色(Decorate)

持有一个构件对象的实例,并实现一个与抽象构件接口一致的接口。

4.具体装饰角色(Concrete Decorate)

负责给构件对象添加附加的责任。

装饰模式的UML图如下:
在这里插入图片描述
下面给出示例代码:
public abstract class Component {
protected abstract void operation();
}

public class ConcreteComponent extends Component {
2     @Override
3     protected void operation() {
4         System.out.println("do something in concreteComponent...");
5     }
6 }
public abstract class Decorate extends Component{
    protected Component component;

    protected void decorate(Component component){
        this.component = component;
    }
}
public class ConcreteDecorateA extends Decorate {

    @Override
    protected void operation() {
        //添加附加操作
        System.out.println("do something in ConcreteDecorateA...");
        //调用被包装类的方法
        component.operation();
    }

}
public class ConcreteDecorateB extends Decorate {

    @Override
    protected void operation() {
        //添加附加操作
        System.out.println("do something in ConcreteDecorateB...");
        //调用被包装类的方法
        component.operation();
    }
    
}

下面给出测试代码:

public class DecorateTest {

    public static void main(String[] args) {
        Component component = new ConcreteComponent();
        ConcreteDecorateA decorateA = new ConcreteDecorateA();
        ConcreteDecorateB decorateB = new ConcreteDecorateB();

        //将ConcreateComponent类包装成ConcreteDecorateA
        decorateA.decorate(component);
        //将ConcreteDecorateA类包装成ConcreteDecorateB
        decorateB.decorate(decorateA);

        decorateB.operation();
    }

}

运行结果:
do something in concreteDecorateB…
do something in concreteDecorateA…
Do something in concreteComponent!
总结:

1.装饰模式的适用场景:

(1)需要扩展一个类的功能、或者给一个类添加附加的职责时。

(2)需要动态的给一个对象添加功能,这些功能可以再动态的撤销时。

(3)需要增加由一些基本功能的排列组合而产生的非常大量的功能,从而使继承关系变得不现实。

(4)当不能采用生成子类的方式进行扩充时。

2.装饰模式的优点:

(1)装饰模式与继承关系的目的都是要扩展对象的功能,但装饰模式可以提供比继承关系更大的灵活性。

(2)通过使用不同的具体装饰类以及这些装饰类的排列组合,可以创造出很多不同行为的组合。

3.装饰模式的缺点:

(1)装饰模式比继承关系更加灵活,但意味着更加复杂。

(2)装饰模式会导致设计中出现很多小类,如果过度使用会使程序变得很复杂。

4.装饰模式与适配器模式的区别:

(1)关于新职责

适配器模式也可以再转换时增加新的功能,但主要目的是为了完成接口的兼容。装饰模式最主要的职责是给装饰类增加新的职责。

(2)关于原接口

适配器模式是用新接口来调用原接口,原接口对新系统来说是不可见或者不可用的。装饰模式原封不动的调用原接口,系统对装饰的对象也是通过原接口来完成使用。

(3)关于装饰的对象

适配器是知道被适配者的详细情况的,而装饰者只知道其接口是什么,至于什么具体类型只有在运行期间才知道。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值