首先提出问题:如何计算在星巴克购买咖啡时,加入各种调料的总费用。
第一种方案如下:
这种方案在一定程度上可以解决类爆炸的问题。但是有引来了新的问题,我们可能会修改调料的价格,或者有了新的调料,在或者某些子类中不包含某些调料。这都会导致我们修改原代码。这与我们的设计原则不符。
我们在提出一条设计原则:
设计原则:类应该对扩展开放,对修改关闭。
第二个方案:
以DarkRoast为例,顾客想要摩卡,就建立一个摩卡对象,并用它将DarkRoast对象包起来。顾客想要奶泡,就建立奶泡对象将摩卡包起来。如图:
然后结算的时候,就可以通过外围的装饰者的cost结算,奶泡的cost会先委托它装饰的对象摩卡计算,最后加上奶泡的价格。
我们可以画出类图:
对应上面的类图,我们可以画出装饰者模式的类图:
这就是装饰者模式:
装饰者模式动态地将责任附加到对象上。若要扩展功能,装饰者提供了比继承更有弹性的替代方案。