前言

起初打算按照之前的日产系列写建造者模式。但参考了网上的很多文章,让我对建造者模式更加的困惑,也害怕自己无法已易懂的方式进行解释。最后通过Google发现了一篇英文文章Builder,使我茅塞顿开。我自己对这篇文章进行了翻译,希望对大家理解建造者模式有帮助。

意图

建造者模式是创建型设计模式,用来逐步创建复杂的对象。使用建造者模式可以使用相同的构造代码生成不同类型、不同表示的对象。

问题

想象一个复杂的对象,它需要大量字段和嵌套对象进行初始化。这种的初始化代码一般会隐藏在一个包含大量参数的庞大构造函数中。

比如,我们来建一个房子对象。建造一个简单的房子需要四面墙、一层地板、一扇门、一对窗户和一个屋顶。但是如果我们想要一个更大更明亮,并且有后院和其他好东西(比如暖气系统、管道和电线)的房子,那该怎么办呢?

最简单的解决方案是继承基本House类并创建一组子类来覆盖所有参数组合,但是后得到大量的子类。任何新的参数都需要进一步扩展这个层次结构。

另一个方法不用派生子类。你可以创建一个包含所有参数的构造函数。这种方法不需要大量的子类,但是存在另外的问题。

在大多数情况下,大部分的参数是不被使用的。这样调用构造函数时会显得代码十分难看。

解决

建造模式建议您从自己的类中提取对象构造代码,将其移动到被称为生成器的独立对象中。

建造者模式将对象构造组织为一组步骤(建墙、建门等)。在Builder对象上执行一系列步骤就可以创建一个对象。最重要的一点是,您无需调用所有的步骤,需要调用需要的步骤即可。

当需要构建产品的各种表现形式时,某些步骤可能需要不同的实现。比如,小屋的墙壁可以用木头建造,但城堡的墙壁需要用石头建造。
这种场景下,可以创建不同的建造者类来实现相同的建造步骤,不同的类型。接下来就可以使用这些建造不同类型的对象。

例如,第一个建造者用木头和玻璃建造一切,第二个用石头和铁建造一切,第三个用黄金和钻石建造一切。通过调用相同的步骤,你可以从第一个建造者那里得到一个普通的房子,从第二个建造者那里得到一个小城堡,从第三个建造者那里得到一个宫殿。

Director

我们可以进一步的将一系列对建造者步骤的调用提取到一个类中,这个类被称为Director。
Director类只定义了执行构建步骤的顺序,而构建器提供了这些步骤的实现。

Direct类不是绝对必要的,我们可以按照特定的顺序直接调用Builder。但是,Director是放置各种可重用构造方案的好方法。
另外,Director类完全隐藏了产品构造的细节。客户端只需要将一个Builder和一个Director关联起来就可以得到构建结果。

结构

  1. Builder接口声明了对所有类型的生成器都通用的产品构造步骤。
  2. Concrete Builders 提供了
    构建步骤的不同实现。
  3. Products是需要产生的对象。不同构造器构建的产品可以属于不同的类层级结构(继承)或者接口。
  4. Director类定义了调用构造步骤的顺序,因此您可以创建和重用产品的特定构造方式。
  5. Client必须将一个Builder对象与Director关联起来。通常,通过director的构造函数的参数只执行一次。然后,director将该Builder对象用于所有的构造。还有一种方式是将Builder对象传递给Director的方法,可以使用不同的生成器。

场景

  • 建造者模式用来拜托过长的构造函数。
  • 创建某些产品的不同表示形式,比如石房和木房。
  • 构造复杂对象,将构造代码和业务代码分离。

    代码

代码我没有粘过来,直接访问参考文献里的底部即可。

参考文献

https://refactoring.guru/design-patterns/builder

大白话建造者模式(Builder Pattern)的更多相关文章

  1. 【原】iOS设计模式之:建造者模式Builder Pattern,用于改进初始化参数

    本文主要讨论一下iOS中的Builder Pattern.与网上很多版本不同,本文不去长篇大论地解释建造者模式的概念,那些东西太虚了.设计模式这种东西是为了解决实际问题的,不能为了设计模式而设计模式, ...

  2. 乐在其中设计模式(C#) - 建造者模式(Builder Pattern)

    原文:乐在其中设计模式(C#) - 建造者模式(Builder Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 建造者模式(Builder Pattern) 作者:webabc ...

  3. 【设计模式】建造者模式 Builder Pattern

    前面学习了简单工厂模式,工厂方法模式以及抽象工厂模式,这些都是创建类的对象所使用的一些常用的方法和套路, 那么如果我们创建一个很复杂的对象可上面的三种方法都不太适合,那么“专业的事交给专业人去做”,2 ...

  4. 建造者模式(Builder Pattern)

    建造者模式(Builder Pattern) 它可以将多个简单的对象一步一步构建成一个复杂的对象. 意图:将一个复杂的构建与其表示相分离,使得同样的构建过程可以创建不同的表示. 主要解决:主要解决在软 ...

  5. 二十四种设计模式:建造者模式(Builder Pattern)

    建造者模式(Builder Pattern) 介绍将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示. 示例用同样的构建过程创建Sql和Xml的Insert()方法和Get()方 ...

  6. iOS设计模式之:建造者模式Builder Pattern,用于改进初始化参数

    转自:http://www.cnblogs.com/wengzilin/p/4365855.html 本文主要讨论一下iOS中的Builder Pattern.与网上很多版本不同,本文不去长篇大论地解 ...

  7. 设计模式系列之建造者模式(Builder Pattern)——复杂对象的组装与创建

    说明:设计模式系列文章是读刘伟所著<设计模式的艺术之道(软件开发人员内功修炼之道)>一书的阅读笔记.个人感觉这本书讲的不错,有兴趣推荐读一读.详细内容也可以看看此书作者的博客https:/ ...

  8. Net设计模式实例之建造者模式(Builder Pattern)

    一.建造者模式简介(Brief Introduction) 建造者模式(Builder Pattern),将一个复杂对象的构建与它的表示分离,使的同样的构建过程可以创建不同的表示. 建造者模式的优点是 ...

  9. Python 设计模式之建造者模式 Builder Pattern

    #引入建造者模式 肯德基的菜单上有 薯条, 鸡腿,鸡翅,鸡米花,可乐,橙汁,火腿汉堡,至尊虾汉堡,牛肉汉堡 , 鸡肉卷等这些单品,也有很多套餐. 比如 套餐1:鸡翅,至尊虾汉堡,可乐,薯条 套餐2:鸡 ...

随机推荐

  1. Python--day40--threading模块

    import time from threading import Thread class MyThread(Thread): def __init__(self,arg): super().__i ...

  2. 2019-10-19-dotnet-给MatterMost订阅RSS博客

    title author date CreateTime categories dotnet 给MatterMost订阅RSS博客 lindexi 2019-10-19 08:12:36 +0800 ...

  3. js基础——对象和数组

    1.Object类型 1)使用new运算符    var box = new Object();===>等同于 var box = Object();(省略new关键字)    box.name ...

  4. C# 在基类定义好方法让子类继承接口就能实现

    在 C# 里面,接口的定义只需要类里面存在和接口声明相同的方法或属性就可以,而存在的方法或属性是在子类定义的还是基类里面定义的都无所谓.也就是在基类里面写好了方法,但不继承接口,等子类继承接口的时候就 ...

  5. H3C 三种生成树协议特性的比较

  6. 2018百度之星初赛B - A,D,F

    总结:这一次的百度之星之行到这里也就结束了,充分的认识到了自己的不足啊...果然还是做的题太少,,见识的题型也还太少,对于STL的掌握还是不够到位啊!!(STL大法是真的好,建议大家认认真真的好好学学 ...

  7. CodeForces 1204 (#581 div 2)

    传送门 A.BowWow and the Timetable •题意 给你一个二进制数,让你求小于这个数的所有4的幂的个数 •思路 第一反应是二进制与四进制转换 (其实不用真正的转换 QwQ) 由于二 ...

  8. HP Z420 工作站主板(X79 , C602)折腾笔记

    公司的电脑有点慢,然后最近运行了SQL Server服务之后,内存又不太够.于是就在淘宝上搜索一些洋垃圾相关的信息.找来找去,发现X79是不错的选择,CPU性能够用,内存价格便宜(16G不到200元) ...

  9. pycharm 更改创建文件默认路径

    1.操作 依次找到以下路径修改为自己想要的路径即可:PyCharm——>Settings——>Appearance&Behavior——>System Setting——&g ...

  10. ELK学习实验006:Nginx的日志分析系统之filebeat配置

    一 Filebeat工作原理 Filebeat由两个主要组件组成: prospector和 harvester 1.1 harvester 负责读取单个文件的内容 如果文件在读取时被制除或重命名, F ...