[Python设计模式] 09 - 建造者模式

设计模式的目的是让代码易维护、易扩展,不能为了模式而模式,因此一个简单的工具脚本是不需要用到任何模式的。

建造者模式:将一个复杂对象的构建与他的表示分离,使得同样的构建过程可以创建不同的表示。

基本思想

  • 某类产品的构建由很多复杂组件组成
  • 这些组件中的某些细节不同,构建出的产品表象会略有不同
  • 通过一个指挥者按照产品的创建步骤来一步步执行产品的创建
  • 当需要创建不同的产品时,只需要派生一个具体的建造者,重写相应的组件构建方法即可

代码结构

class Builder(object):
    """基类"""
    def Part1(self):
        # 不同类型的产品,该步骤的细节可能不同
        raise NotImplementedError()      

    def Part2(self):
        # 不同类型的产品,该步骤的细节可能不同
        raise NotImplementedError()

class Builder1(Builder):
    """派生类,生产builder1类型的产品""" 
    def Part1(self):
        print 'builder1 Part1'

    def Part2(self):
        print 'builder1 Part2'

class Builder2(Builder):
    """派生类,生产builder2类型的产品"""
    def Part1(self):
        print 'builder2 Part1'

    def Part2(self):
        print 'builder2 Part2'

class Director(object):
    """指挥者,负责组织产品的构建过程"""
    def Build(self, builder):
        builder.Part1()
        builder.Part2()

def client():
    director = Director()
    director.Build(Builder1())
    director.Build(Builder2())

这里有一个疑问,指挥者这个角色有什么用呢。感觉除了增加client的调用负担外,似乎没什么用处。为什么不把产品构建过程放在Builder基类中呢,像下面这样:

class Builder(object):
    """基类"""
    def Part1(self):
        raise NotImplementedError()      

    def Part2(self):
        raise NotImplementedError()

    def Build(self):
        self.Part1()
        self.Part2()

class Builder1(Builder):
    def Part1(self):
        print 'builder1 Part1'

    def Part2(self):
        print 'builder1 Part2'

class Builder2(Builder):
    def Part1(self):
        print 'builder2 Part1'

    def Part2(self):
        print 'builder2 Part2'

def client():
    Builder1().Build()
    Builder2().Build()

没错,上面就是典型的模板方法模式的实现套路,回顾一下模板方法模式的定义:

模板方法模式:定义一个工作流或算法的基本骨架,而将一些特定步骤的实现延迟到子类中。

模板方法模式更多的关注于算法流程,而建造者模式更多的关注于复杂对象的创建,模板模式应用场景比建造者模式更多一些,写起来也更自然一些。

建造者模式将产品的创建流程提取到指挥者中,建造者则扮演机器人的角色,没有自主意识,只知道按照命令做相应的工作,建造者模式的适应场景有限且明确,在特定场景下的优势是比较明显的。更多关于建造者模式的解释可以参考:

原文地址:http://www.isware.cn/python-design-pattern/09-builder/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容