生成器模式是创建型设计模式。

设计意图:将一个复杂的类表示与其构造相分离,使得同样的构建过程可以得出不同的表示。

实例类图:

IVehicleBuilder:抽象建造者。为创建一个Vehicle对象并创建它的相关部件指定的抽象接口,把产品的生产过程分解为不同的步骤,从而使详细的建造者在详细的建造步骤上具有很多其它弹性,从而创造出不同表示的产品。(这里就是小车和卡车)

CarBuilder、TrunkBuilder:详细建造者,实现IVehicleBuilder接口,构造和装配产品的各个部件定义并明白它所创建的表示,提供一个返回这个产品的接口。

Director:指挥者,构建一个使用IVehicleBuilder接口的对象。

Vehicle:汽车产品,被构建的复杂对象,详细产品建造者,创建该产品的内部表示并定义它的装配过程。

我们先看一下Director都做了什么!

package com.builder;

import com.factory.abstrcatfactory.model.Engine;
import com.factory.abstrcatfactory.model.Tank;
import com.factory.abstrcatfactory.model.Vehicle; /**构建器的指挥者
* 构建器模式能够构建同样步骤的两个系列商品
* 在构建同样步骤的系列商品上,代码量上要优于抽象工厂模式,可是每一个产品的不同步骤产品的添加时抽象工厂更有优势,由于功能类隔离性更好。
* @author gaoxu
* 实践出真知! */
public class Director {
private IVehicleBuilder _vehicleBuilder = null; public Director(IVehicleBuilder vehicleBuilder){
_vehicleBuilder = vehicleBuilder;
} public Vehicle createVehicle(){
Engine engine = _vehicleBuilder.builderEngine();
Tank tank = _vehicleBuilder.builderTank();
Vehicle vehicle = _vehicleBuilder.builderVehicle(engine,tank);
return vehicle;
}
}

我们看到指挥者负责指挥建造产品,再来看一下client的代码。我们就清楚指挥者有多重要了,生成器模式必须有指挥者。

package com.builder;

import com.factory.abstrcatfactory.model.Vehicle;

/**
* @author gaoxu
* 实践出真知! */
public class Client {
public static void main(String[] para){
//小车
IVehicleBuilder carBuilder = new CarBuilder();
Director director = new Director(carBuilder);
Vehicle car = director.createVehicle();
//卡车
IVehicleBuilder trunkBuilder = new TrunkBuilder();
Director directorT = new Director(trunkBuilder);
Vehicle trunk = directorT.createVehicle();
}
}

我们再来看详细构建者的代码。我们就清楚了。每一个详细构建器都是一个产品的构建总体过程的详细实现。

小车详细构建者,构建发动机、构建油箱。构建小车。

这些都封装在详细的构建器中,这样构建与表示就显示的分离,显示在client端没有不论什么详细构建者内容的影子,全然封装了起来。

package com.builder;

import com.factory.abstrcatfactory.model.Engine;
import com.factory.abstrcatfactory.model.Tank;
import com.factory.abstrcatfactory.model.Vehicle; /**小车详细实现类
* @author gaoxu
* 实践出真知!
*/
public class CarBuilder implements IVehicleBuilder { @Override
public Engine builderEngine() {
// TODO Auto-generated method stub
return null;
} @Override
public Tank builderTank() {
// TODO Auto-generated method stub
return null;
} @Override
public Vehicle builderVehicle(Engine engine,Tank tank) {
// TODO Auto-generated method stub
return null;
} }
package com.builder;

import com.factory.abstrcatfactory.model.Engine;
import com.factory.abstrcatfactory.model.Tank;
import com.factory.abstrcatfactory.model.Vehicle; /**卡车详细实现类
* @author gaoxu
* 实践出真知! */
public class TrunkBuilder implements IVehicleBuilder { @Override
public Engine builderEngine() {
// TODO Auto-generated method stub
return null;
} @Override
public Tank builderTank() {
// TODO Auto-generated method stub
return null;
} @Override
public Vehicle builderVehicle(Engine engine,Tank tank) {
// TODO Auto-generated method stub
return null;
} }

上边的实例也是创建汽车。我们能够看到相同是创建汽车,生成器模式要比抽象工厂模式的代码量少非常多非常多,当然在解耦方面还是抽象工厂更好一些,由于生成器中的详细构建器中有全部的产品部件的构建过程。假设这个过程更复杂那么详细构建器将非常庞大,改动起来错误率也会非常高。而抽象工厂在这方面还是比較好的,每一个部件都是独立的构建接口与类。

跟着实例学习设计模式(6)-生成器模式builder(创建型)的更多相关文章

  1. 设计模式03: Builder 生成器模式(创建型模式)

    Builder生成器模式(创建型模式) Builder模式缘起假设创建游戏中的一个房屋House设施,该房屋的构建由几个部分组成,且各个部分富于变化.如果使用最直观的设计方法,每个房屋部分的变化,都将 ...

  2. 设计模式十: 生成器模式(Builder Pattern)

    简介 生成器模式属于创建型模式的一种, 又叫建造者模式. 生成器模式涉及4个关键角色:产品(Product),抽象生成器(builder),具体生成器(ConcreteBuilder),指挥者(Dir ...

  3. 【设计模式】- 生成器模式(Builder)

    生成器模式 建造者模式.Builder 生成器模式 也叫建造者模式,可以理解成可以分步骤创建一个复杂的对象.在该模式中允许你使用相同的创建代码生成不同类型和形式的对象. 生成器的结构模式 生成器(Bu ...

  4. Java设计模式05:常用设计模式之原型模式(创建型模式)

    1. Java之原型模式(Prototype Pattern)     原型模式属于对象的创建模式.通过给出一个原型对象来指明所有创建的对象的类型,然后用复制这个原型对象的办法创建出更多同类型的对象. ...

  5. Java设计模式02:常用设计模式之工厂模式(创建型模式)

    一.工厂模式主要是为创建对象提供过渡接口,以便将创建对象的具体过程屏蔽隔离起来,达到提高灵活性的目的.  工厂模式在<Java与模式>中分为三类: 1)简单工厂模式(Simple Fact ...

  6. Java设计模式04:常用设计模式之建造者模式(创建型模式)

    1. Java之建造者模式(Builder Pattern) (1)概念:       将一个复杂的构建与其表示相分离,使得同样的构建过程可以创建不同的表示. [ 构建与表示分离, 同构建不同表示 ] ...

  7. 跟着实例学习设计模式(7)-原型模式prototype(创建型)

    原型模式是创建型模式. 设计意图:用原型实例指定创建对象的类型,并通过拷贝这个原型来创建新的对象. 我们使用构建简历的样例的类图来说明原型模式. 类图: 原型模式主要用于对象的复制.它的核心是就是类图 ...

  8. 每天一个设计模式-7 生成器模式(Builder)

    每天一个设计模式-7 生成器模式(Builder) 一.实际问题 在讨论工厂方法模式的时候,提到了一个导出数据的应用框架,但是并没有涉及到导出数据的具体实现,这次通过生成器模式来简单实现导出成文本,X ...

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

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

随机推荐

  1. The C programming language [book]

    1 A12.3 Macro Definition and Expansion A control line of the form #define identifier token-sequence ...

  2. 设置div自适应高度滚动

    <body> <div id="divc" style="overflow: auto;"> </div> <a id ...

  3. ASP.NET MVC创建静态页

    1.在MVC下新建一个类:StaticPageHelper public class StaticPageHelper { /// <summary> /// 根据View视图生成静态页面 ...

  4. ansible 手册

    ansible 官方文档:https://docs.ansible.com/ansible/latest/index.html ansible 中文入门:http://getansible.com/ ...

  5. 分享Kali Linux 2017年第17周镜像文件

     分享Kali Linux 2017年第17周镜像文件  Kali Linux官方于4月23日发布2017年的第17周镜像.这次维持了11个镜像文件的规模.默认的Gnome桌面的4个镜像,E17.KD ...

  6. mysql共享锁与排它锁

    共享锁shared lock(也叫读锁read lock)又称读锁,若事务T对数据对象A加上S锁,则事务T可以读A但不能修改A,其他事务只能再对A加S锁,而不能加X锁,直到T释放A上的S锁.这保证了其 ...

  7. ios修改hosts文件后访问网址114导航域名无法解析问题

    当前的问题是打开hosts文件转换成utf8格式浏览发现前面有@之类的非法字符,手动修改后可以访问.

  8. Android自定义控件-Path之贝赛尔曲线和手势轨迹、水波纹效果

    从这篇开始,我将延续androidGraphics系列文章把图片相关的知识给大家讲完,这一篇先稍微进阶一下,给大家把<android Graphics(二):路径及文字>略去的quadTo ...

  9. PHP树生成迷宫及A*自己主动寻路算法

    PHP树生成迷宫及A*自己主动寻路算法 迷宫算法是採用树的深度遍历原理.这样生成的迷宫相当的细,并且死胡同数量相对较少! 随意两点之间都存在唯一的一条通路. 至于A*寻路算法是最大众化的一全自己主动寻 ...

  10. SGU 231 Prime Sum 求&lt;=n内有多少对素数(a,b)使得a+b也为素数 规律题

    题目链接:contest=0&problem=231">点击打开链接 题意: 求<=n内有多少对素数(a,b)使得a+b也为素数 思路: 我们发现全部素数间隔都是> ...