装饰器模式
装饰器模式,动态地给一个对象添加一些额外的职责,就增加功能来说,装饰器模式比生成子类更为灵活。
代码示例
代码解读
该例子基于的需求:客户点饮料系统,在用户下单的过程中,可以对饮料进行相应的定制。
1、先定义了Beverage类,所有的饮料都是由该类继承而来;
2、定义drinkDecorator类,所有需要新增的功能都是由该类继承而来;
3、定义了iceDecorator类,对所点的饮料进行加冰,并且加冰后价格也需要增加;定义了sugarDecorator类,对所点的饮料进行加糖,并且加糖后价格也需要增加。
4、在客户端调用时,先生成milk1实例,然后在对milk1加冰的过程中,在iceDecorator初始化的时候就将milk1实例传入,在调用getName和getPrice时,调用milk1实例的方法后,接着处理milk1方法返回的结果,从而达到动态的更改getName和getPrice方法。
装饰器模式应用场景:
需要扩展、增强或者减弱一个类的功能。
优点
1、装饰器模式时继承方式的一个替代方案,可以轻量级的扩展被装饰对象的功能;
2、Python的装饰器模式是实现AOP的一种方式,便于相同操作位于不同调用为止的统一管理。
缺点
1、多层装饰器的调试和维护较困难。
Python装饰器模式的通用代码
python 中的装饰器编写过程:
先定义装饰器函数
该函数的调用过程如下:
当调用drugPrice(func)函数时,返回的是wrapper函数,该函数是func(self,*args,**kwargs),在wrapper(self,*args,**kwargs)的时候,就是调用的func(self,*args,**kwargs)函数,只不过此时还执行了print(self,args,kwargs);self.price += 2这段语句。
@drugPrice会被Python解析为getPrice=drugPrice(getPrice),此时可以理解为如下的执行顺序
然后调用getPrice()函数就会把装饰器里面的内容执行完成。