装饰器模式(Decorator Pattern)允许向一个现有的对象添加新的功能,同时又不改变其结构。这种类型的设计模式属于结构型模式,它是作为现有的类的一个包装。这种模式创建了一个装饰类,用来包装原有的类,并在保持类方法签名完整性的前提下,提供了额外的功能。它的核心结构有四个角色:抽象构件(Component)、具体构件(ConcreteComponent)、抽象装饰器(Decorator)、具体装饰器(ConcreteDecorator)
我们通过下面的实例来演示装饰器模式的用法。我们以手抓饼为例,手抓饼可以只买一个饼,也可以加香肠、鸡蛋、培根、里脊肉等等,可以自由组合成不同的套餐。这里手抓饼扮演具体ConcreteComponent角色,手抓饼里加的配料扮演ConcreteDecorator角色。
类图 示例抽象构件件
public abstract class ShreddedPancake { protected abstract String getMessage(); protected abstract int getPrice(); }
具体构件
public class NormalShreddedPancake extends ShreddedPancake{ @Override protected String getMessage() { return "手抓饼"; } @Override protected int getPrice() { return 3; } }
抽象装饰器
public abstract class ShreddedPancakeDecorator extends ShreddedPancake{ private ShreddedPancake shreddedPancake; public ShreddedPancakeDecorator(ShreddedPancake shreddedPancake) { this.shreddedPancake = shreddedPancake; } @Override protected String getMessage() { return shreddedPancake.getMessage(); } @Override protected int getPrice() { return shreddedPancake.getPrice(); } }
具体装饰器1
public class EggDecorator extends ShreddedPancakeDecorator{ public EggDecorator(ShreddedPancake shreddedPancake) { super(shreddedPancake); } @Override protected String getMessage() { return super.getMessage() + " + 1个鸡蛋"; } @Override protected int getPrice() { return super.getPrice() + 1; } }
具体装饰器2
public class BaconDecorator extends ShreddedPancakeDecorator{ public BaconDecorator(ShreddedPancake shreddedPancake) { super(shreddedPancake); } @Override protected String getMessage() { return super.getMessage() + " + 1块培根"; } @Override protected int getPrice() { return super.getPrice() + 2; } }
客户端
public static void main(String[] args) { ShreddedPancake shreddedPancake = new NormalShreddedPancake(); System.out.println(shreddedPancake.getMessage() + ", 总价格:" + shreddedPancake.getPrice()); ShreddedPancake shreddedPancake1 = new EggDecorator(shreddedPancake); System.out.println(shreddedPancake1.getMessage() + ", 总价格:" + shreddedPancake1.getPrice()); ShreddedPancake shreddedPancake2 = new BaconDecorator(new EggDecorator(shreddedPancake)); System.out.println(shreddedPancake2.getMessage() + ", 总价格:" + shreddedPancake2.getPrice()); }
我们可以看到,使用了装饰器模式后,可以给原有的类包装一层又一层,就像俄罗斯套娃一样。这样我们如果想新增功能的话,只要新增一个装饰器类就好了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)