大战设计模式17—— 建造者模式
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了大战设计模式17—— 建造者模式相关的知识,希望对你有一定的参考价值。
建造者模式(Builder)
设计模式使用的例子https://github.com/LinkinStars/DesignPatternsAllExample
一、定义
将一个复杂对象的构建与它的表示相分离,使得同样的构建过程可以创建不同的表示。
二、结构
Builder(抽象建造者):为创建一个产品对象的各个部件指定抽象接口,在其接口中一般包含两类方法:一类是BuildPartX(),用于创建复杂对象的各个部件;
另一类是GetResult(),用于返回生成好的复杂对象。它就可以是抽象类,也可以是接口。
ConcreteBuilder(具体建造者):实现了Builder接口,即实现了各个部件的具体构造和装配方法,定义并明确其所创建的复杂对象。
Product(产品角色):被构建的复杂对象,包含多个组成部件。
Director(指挥者):负责安排复杂对象的建造次序,指挥者与抽象建造者之间存在关联关系,可以在其Construct()方法中调用建造者对象的部件构造和装配方法,完成复杂对象的建造。
因此,客户端只需要和指挥者进行交互,这也确保了单一职责。
三、优点
客户端不需要知道产品内部的组成细节,将产品本身与产品的创建过程解耦,使得相同的创建过程可以创建不同的产品对象。
具体建造者相对独立,增加新的具体建造者无需修改原有类库的代码,系统扩展比较方便,符合开闭原则。
可以更加精细地控制产品的创建过程,将复杂产品的创建步骤分解在不同的方法中,使得创建过程更加清晰,也更方便使用程序来控制创建过程。
四、缺点
对于所创建的产品有一定限制:一般这些产品都具有一些较多的共同点,其组成部分相似。如果差异性很大,那么则不适合使用建造者模式。
如果产品的内部结构复杂多变,可能会需要定义很多具体构建者来实现这些变化,会导致系统变得庞大,增加系统的理解难度和运行成本。
五、应用场景
需要生成的产品对象由复杂的内部结构,这些产品对象通常包含多个成员变量。
需要生成的产品对象的属性相互依赖,需要指定其生成顺序。
隔离复杂对象的创建和使用,并使得相同的创建过程可以创建不同的产品。
六、个人总结
1、建造者模式是用来生产对象的,告诉指挥者你需要什么样的对象,他就给你建造什么样的对象。
2、建造者的任务是组装一个个零件,最终建造出一个你所需要的对象。就如例子中,我们需要建造一个大人和一个小孩对象
我们只要告诉指挥者我们需要什么样的对象就可以了,他就会帮我们建造好一个完整的对象。
3、建造者模式一个重点是向客户隐藏了产品的内部表现。
4、建造者模式与抽象工厂模式有点相似,但是建造者模式返回一个完整的复杂产品,而抽象工厂模式则返回一系列相关的产品。
如果将抽象工厂模式看成一个汽车配件生产厂,生成不同类型的汽车配件;
那么建造者模式则是一个汽车组装厂,通过对配件进行组成返回一辆完整的汽车。
参考博客:http://www.cnblogs.com/edisonchou/p/6828436.html
以上是关于大战设计模式17—— 建造者模式的主要内容,如果未能解决你的问题,请参考以下文章