装饰器模式允许用户在不改变其结构的情况下向现有对象添加新功能。 这种类型的设计模式属于结构模式,因为此模式充当现有类的包装。
这个模式创建了一个装饰器类,它封装了原始类,并提供了额外的功能,保持了类方法签名的完整性。
装饰者模式的动机是动态地附加对象的额外职责(功能)。
下面提到的代码是如何在python中实现装饰器设计模式的简单演示。 该示例涉及以类形式展示咖啡店(coffeeshop
类)。 创建的 coffee
类是一个抽象类,这意味着它不能被实例化。
import six
from abc import abcmeta
@six.add_metaclass(abcmeta)
class abstract_coffee(object):
def get_cost(self):
pass
def get_ingredients(self):
pass
def get_tax(self):
return 0.1*self.get_cost()
class concrete_coffee(abstract_coffee):
def get_cost(self):
return 1.00
def get_ingredients(self):
return 'coffee'
@six.add_metaclass(abcmeta)
class abstract_coffee_decorator(abstract_coffee):
def __init__(self,decorated_coffee):
self.decorated_coffee = decorated_coffee
def get_cost(self):
return self.decorated_coffee.get_cost()
def get_ingredients(self):
return self.decorated_coffee.get_ingredients()
class sugar(abstract_coffee_decorator):
def __init__(self,decorated_coffee):
abstract_coffee_decorator.__init__(self,decorated_coffee)
def get_cost(self):
return self.decorated_coffee.get_cost()
def get_ingredients(self):
return self.decorated_coffee.get_ingredients() + ', sugar'
class milk(abstract_coffee_decorator):
def __init__(self,decorated_coffee):
abstract_coffee_decorator.__init__(self,decorated_coffee)
def get_cost(self):
return self.decorated_coffee.get_cost() + 0.25
def get_ingredients(self):
return self.decorated_coffee.get_ingredients() + ', milk'
class vanilla(abstract_coffee_decorator):
def __init__(self,decorated_coffee):
abstract_coffee_decorator.__init__(self,decorated_coffee)
def get_cost(self):
return self.decorated_coffee.get_cost() + 0.75
def get_ingredients(self):
return self.decorated_coffee.get_ingredients() + ', vanilla'
如下所述,coffeeshop
抽象类的实现是通过一个单独的文件完成的 -
import coffeeshop
mycoffee = coffeeshop.concrete_coffee()
print('ingredients: '+mycoffee.get_ingredients()+
'; cost: '+str(mycoffee.get_cost())+'; sales tax = '+str(mycoffee.get_tax()))
mycoffee = coffeeshop.milk(mycoffee)
print('ingredients: '+mycoffee.get_ingredients()+
'; cost: '+str(mycoffee.get_cost())+'; sales tax = '+str(mycoffee.get_tax()))
mycoffee = coffeeshop.vanilla(mycoffee)
print('ingredients: '+mycoffee.get_ingredients()+
'; cost: '+str(mycoffee.get_cost())+'; sales tax = '+str(mycoffee.get_tax()))
mycoffee = coffeeshop.sugar(mycoffee)
print('ingredients: '+mycoffee.get_ingredients()+
'; cost: '+str(mycoffee.get_cost())+'; sales tax = '+str(mycoffee.get_tax()))
执行上述程序生成以下输出 -