1、模式简介

  建造者模式也叫生成器模式,和抽象工厂模式相似,也是一种构建复杂对象的模式。

建造者模式中的角色分类:

  • 抽象建造者Builder:接口类型,用于规范各个产品的组成部分;
  • 具体建造者ConcreteBuilder:实现Builder中的所有方法,并且返回一个构造好的产品实例;
  • 指导者Director:根据用户的需求安排产品各组件的生产顺序,然后告诉具体建造者开始建造;
  • 产品Product:用户最终看到的复杂对象。

各组成部分之间的UML框架如下图所示:

2、代码

  项目框架如下图所示:

  产品的组成部分Part父类中的代码:

public class Part {
private String name; protected void setName(String name) {
this.name = name;
} public void onPartPrepared() {
System.out.println(this.name + "prepared......");
}
}

  Part的子类PartA中的代码:

public class PartA extends Part {
public PartA() {
super.setName("PartA");
}
}

  产品类Product中的代码:

public class Product {
private List<Part> parts; public Product() {
this.parts = new ArrayList<>();
} public void addComponent(Part part) {
parts.add(part);
} public void display() {
for (Part p : parts) {
p.onPartPrepared();
}
System.out.println();
}
}

  建造者的父类Builder中的代码:

public abstract class Builder {
protected Product product; public abstract Product buildProduct();
}

  Builder的子类ProductBuilder1中的代码:

public class ProductBuilder1 extendsBuilder {

      @Override
public Product buildProduct() {
super.product = new Product();
super.product.addComponent(new PartA());
super.product.addComponent(new PartB());
super.product.addComponent(new PartD());
return super.product;
}
}

  指导者Director中的代码:

public class Director {
private String name;
private Builder builder; public Director(String name, Builder builder) {
this.name = name;
this.builder = builder;
} public void constructComponent() {
System.out.println("Preparing Components For " + name);
Productproduct = builder.buildProduct();
product.display();
}
}

  测试类Test中的代码:

public class Test {
public static void main(String[] args) {
Directordirector1 = new Director("Product 01", new ProductBuilder1());
director1.constructComponent(); Directordirector2 = new Director("Product 02", new ProductBuilder2());
director2.constructComponent(); Directordirector3 = new Director("Product 03", new ProductBuilder3());
director3.constructComponent();
}
}

  运行结果如下图所示:

3、总结

符合以下要求的对象可以使用建造者模式来创建:

  • 需要创建的对象是一个组合结构;
  • 需要创建的对象的创建过程不必被用户知道;
  • 允许对象通过多个步骤来创建,并且可以改变过程。

建造者模式的优点:

  • 封装了对象创建的具体代码;
  • 可以更加精细的控制对象的构造过程;
  • 将对象的创建过程与创建该对象的类解耦,提高了灵活性;
  • 指挥者的代码不需要修改,符合“开闭原则”。

建造者模式的缺点:

  每种对象的创建以及同一种对象的不同方式的创建都需要一个单独的具体建造者类。

建造者模式与抽象工厂模式的区别:

  • 建造者模式构建对象是一步一步完成的,关注的是各零件的工艺顺序;而抽象工厂模式将一个系列的产品看作一个整体,即将这个系列的产品的构造封装成一个方法,最终直接返回产品;
  • 抽象工厂模式中用户是直接与工厂交互的,通过将用户需求传达给工厂直接生产产品;而建造者模式中用户是与指导者交互的,由指导者与建造者交流生产产品。

  从上面的区别可以看出,建造者模式适合生产的产品复杂度比抽象工厂模式适合生产的产品的复杂度要高。

  最后贴出建造者模式的GitHub地址:【GitHub - Builder】

【设计模式 - 3】之建造者模式(Builder)的更多相关文章

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

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

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

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

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

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

  4. IOS设计模式浅析之建造者模式(Builder)

    定义 "将一个复杂对象的构建与它的表现分离,使得同样的构建过程可以创建不同的表现". 最初的定义出现于<设计模式>(Addison-Wesley,1994). 看这个概 ...

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

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

  6. 设计模式 笔记 生成器(建造者)模式 Builder

    //---------------------------15/04/08---------------------------- //builder 生成器(建造者)模式---对象创建型模式 /* ...

  7. 设计模式学习之建造者模式(Builder,创建型模式)(6)

    假如我们需要建造一个房子,并且我们也不知道如何去建造房子,所以就去找别人帮我们造房子 第一步: 新建一个房子类House,里面有房子该有的属性,我们去找房子建造者接口HouseBuilder,我们要建 ...

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

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

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

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

  10. 设计模式-05建造者模式(Builder Pattern)

    1.模式动机 比如我们要组装一台电脑,都知道电脑是由 CPU.主板.内存.硬盘.显卡.机箱.显示器.键盘和鼠标组成,其中非常重要的一点就是这些硬件都是可以灵活选择,但是组装步骤都是大同小异(可以组一个 ...

随机推荐

  1. 【Java多线程与并发库】4.传统线程同步通信技术

    我们先通过一道面试题来了解传统的线程同步通信. 题目:子线程循环10次,接着主线程循环100次,接着又回到子线程循环10次,接着再回到主线程又循环100次,如此循环50次,请写出程序. 我没有看答案, ...

  2. 关闭linux终端命令行退格报警声(centos7亲测有效)

    首先这个声音不是外置音频设备发出,而是主板上的蜂鸣器 1,使用root账户登录 2,vi 打开 ~/.bashrc 脚本 3,在脚本的最后一行加上 setterm -blength 0  4,保存脚本 ...

  3. php模块参考

    <?php //数据库连接类 class ConnDB{ var $dbtype; var $host; var $user; var $pwd; var $dbname; //构造方法 fun ...

  4. APCS

    arm汇编程序中,R0,R1,R2,R3,R12都是作为中间寄存器,而R4-R11是不能随便使用的,暂时我还不知它们的用途.所以,中间寄存器,在程序运行的开始处与结束的时候值是可以不一样的,也就是说中 ...

  5. bzoj2011: [Ceoi2010]Mp3 Player

    Description Georg有个MP3 Player,没有任何操作T秒钟就会锁定,这时按下任意一个键就会变回没锁定的状态,但不会改变频道.只有在没锁定的状态下按键才有可能改变频道. MP3的频道 ...

  6. Socket 错误总结

    错误 因为并没有搞清楚accept函数的使用,所以导致不停的发送失败,同时还不知道错误在哪里,无意中看见errno这个库,可以记录错误的原因,才知道原因在于没有用客户端的套接字进行接收数据,而这个客户 ...

  7. (三大框架SSH)面试题锦集

    http://www.cnblogs.com/dieyf/p/4109233.html

  8. [HDOJ - 5208] Where is Bob 【DFS+按位贪心】

    题目链接:HDOJ - 5208 题目分析 使用按位贪心的思想,即从高位向低位枚举,尽量使这一位的答案为 1 . 我们使用 DFS ,每次就是对于  [l1, r1] [l2, r2] x  进行处理 ...

  9. 使用2to3将代码移植到Python 3-转

    http://m.blog.csdn.net/blog/merryken/9104199# ❝ Life is pleasant. Death is peaceful. It’s the transi ...

  10. 转-Python optionParser模块的使用方法

    Python  有两个内建的模块用于处理命令行参数: 一个是  getopt,<Deep in python>一书中也有提到,只能简单处理 命令行参数: 另一个是  optparse,它功 ...