[设计模式] - 装饰者模式 要要切割闹,煎饼果子来一套

装饰者模式是指在不改变原有对象的基础上, 将功能附加到对象上,提供了比继承更有弹性的代替方案。

装饰者模式适用场景

  1. 用于扩展一个类的功能或给一个类添加附加职责
  2. 动态的给一个对象添加功能,这些功能可以动态的撤销

装饰者模式的应用场景

比如说我早晨最爱吃的早点就是煎饼,夹油条或夹脆饼再来根烤肠,越想越香呀~~
首先我们先创建一个抽象的BatterCake

public abstract class BatterCake {

    protected abstract String getName();

    protected abstract int getPrice();
}

创建一个基本的煎饼 BaseBatterCake

public class BaseBatterCake extends BatterCake {
    @Override
    protected String getName() {
        return "煎饼";
    }

    @Override
    protected int getPrice() {
        return 5;
    }
}

再扩展一下套餐的抽象装饰者BatterCakeDecorator

public abstract class BatterCakeDecorator extends BatterCake{

    private BatterCake batterCake;

    public BatterCakeDecorator(BatterCake batterCake) {
        this.batterCake = batterCake;
    }

    protected abstract void doSomething();

    @Override
    protected String getName() {
        return this.batterCake.getName();
    }

    @Override
    protected int getPrice() {
        return this.batterCake.getPrice();
    }
}

创建鸡蛋装饰者类

public class EggDecorator extends BatterCakeDecorator {
    public EggDecorator(BatterCake batterCake) {
        super(batterCake);
    }

    @Override
    protected void doSomething() {

    }

    @Override
    protected String getName() {
        return super.getName()+" egg";
    }

    @Override
    protected int getPrice() {
        return super.getPrice()+1;
    }
}

香肠装饰者类

public class SausageDecorator extends BatterCakeDecorator {
    public SausageDecorator(BatterCake batterCake) {
        super(batterCake);
    }

    @Override
    protected void doSomething() {

    }

    @Override
    protected int getPrice() {
        return super.getPrice()+2;
    }

    @Override
    protected String getName() {
        return super.getName()+" sausage";
    }
}

测试一下

public class Test {

    public static void main(String[] args) {
        BatterCake batterCake;

        batterCake = new BaseBatterCake();

        batterCake = new EggDecorator(batterCake);

        batterCake = new EggDecorator(batterCake);

        batterCake = new SausageDecorator(batterCake);

        System.out.println(batterCake.getName());
        System.out.println(batterCake.getPrice());
    }
}

通过测试可以看到,首先创建一个基础煎饼,然后通过不断增加套餐内容其中价格也会自动变化。装饰者的本质特征就是将原有的类的附加功能抽离出来,简化原有的逻辑。

装饰者模式和适配器模式对比

装饰者模式 适配器模式
形式 特别的适配器模式,包含层级关系 没有层级关系
定义 装饰者和被装饰者都实现了同一个接口,主要目的是为了扩展之后依旧保留OOP关系 适配器和被适配者没有必然的联系,通常采用继承或代理的形式进行包装
关系 满足 is-a的关系 满足has-a的关系
功能 注重覆盖,扩展 注重兼容,转换
设计 前置考虑 后置考虑

装饰者模式的优缺点

优点:

  1. 装饰者是继承有力补充,比继承灵活,不改变原有对象的情况下动态的给一个对象扩展功能
  2. 通过不同的装饰类以及这些装饰类的不同组合可实现不同效果
  3. 装饰者模式准守开闭原则
    缺点:
  4. 会出现更多的代码,更多的类,增加程序的复杂性
  5. 动态装饰时多层装饰更为复杂

你可能感兴趣的:(设计模式,设计模式,装饰者模式)