这篇文章将为大家详细讲解有关Python设计模式之装饰模式的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
具体如下:
装饰模式(Decorator Pattern):动态的给一个对象添加一些额外的职责,就增加功能来说,装饰模式比生成子类更为灵活.
下面是一个给人穿衣服的过程,使用装饰模式:
#!/usr/bin/env python # -*- coding:utf-8 -*- __author__ = 'Andy' """ 大话设计模式 设计模式——装饰模式 装饰模式(Decorator Pattern):动态的给一个对象添加一些额外的职责,就增加功能来说,装饰模式比生成子类更为灵活. 特点: 有效的把类的核心职责和装饰功能区分开,而且可以去除相关类中重复的装饰逻辑 """ # 定义对象接口 class Person(object): def __init__(self,name): self.name = name def show(self): print "装扮的%s"%self.name #装饰类 class Finery(Person): def __init__(self): pass def Decorate(self,componet): self.componet = componet def show(self): if self.componet != None: self.componet.show() #装扮——T恤 class TShirts(Finery): def __init__(self): pass def show(self): print 'T恤' self.componet.show() #装扮——大裤衩 class BigTrouser(Finery): def __init__(self): pass def show(self): print '大裤衩' self.componet.show() # 装扮——人字拖 class FlipFlops(Finery): def __init__(self): pass def show(self): print '人字拖' self.componet.show() if __name__ == '__main__': p = Person('Andy') ff = FlipFlops() bt = BigTrouser() ts = TShirts() ff.Decorate(p) bt.Decorate(ff) ts.Decorate(bt) ts.show()运行结果:
T恤
大裤衩
人字拖
装扮的Andy
这几个类的设计如下图:
通过一个个继承自装饰类Finery的对象,实现给Person类赋予职责的功能,Person类并不会感知Finery的存在。
关于“Python设计模式之装饰模式的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。