假设要组装一辆自行车,并且自行车就是车轮和车架组成。

Builder对应于组装自行车所使用的车轮和车架

ConcreteBuiler对应于自行车的车轮和车架,同时可以返回一辆自行车。

Product对应于自行车。

Director表示组装过程。

此时我们再来理解下面这句话:“在软件系统中,有时候面临着“一个复杂对象”的创建工作,其通常由各个部分的子对象用一定的算法构成;由于需求的变化,这个复杂对象的各个部分经常面临着剧烈的变化,但是将它们组合在一起的算法确相对稳定。”

自行车就是“一个复杂对象”,它有车轮和车架组成,但不管车轮和车架这两个部件怎么变化,生产一辆自行车的过程是不会变的,即组装过程是不会变的。

下面是java示例代码:

/**
* A bike as a concrete product we got finally
*
*/
public class Bike {
//自行车车架数量
int frameNumber;
//自行车轮子数量
int wheelNumber;
public Bike(){
frameNumber = 1;
wheelNumber = 4;
}
public int getFrameNumber() {
return frameNumber;
} public int getWheelNumber() {
return wheelNumber;
} }
/**
*
* An abstract Builder
*/
public abstract class BikeBuilder {
//构建bike的框架
public abstract void BuildFrame(int frameNumber);
//构建bike的轮子
public abstract void BuildWheels(int wheelNumber);
//获取构建好的完整的产品
public abstract Bike getBike();
}
/**
*
*构建自行车的各个部件
*/
public class ConcreteBikeBuilder extends BikeBuilder {
Bike bike;
public ConcreteBikeBuilder(){
bike = new Bike();
}
@Override
public void BuildFrame(int frameNumber) {
bike.frameNumber = frameNumber;
} @Override
public void BuildWheels(int wheelNumber) {
bike.wheelNumber = wheelNumber;
} @Override
public Bike getBike() { return bike;
} }
/**
*
*组装自行车
*/
public class BikeDirector {
public void createBike(BikeBuilder concreteBuilder){
concreteBuilder.BuildFrame(1);
concreteBuilder.BuildWheels(4);
}
}
public class TestClient {

	public static void main(String[] args) {
Bike bike = new Bike();
BikeBuilder builder = new ConcreteBikeBuilder();
BikeDirector director = new BikeDirector();
director.createBike(builder);
bike = builder.getBike();
System.out.println("车架frame:" + bike.getFrameNumber()+"个");
System.out.println("轮子wheel:" + bike.getWheelNumber()+"个");
}
}

测试结果:

车架frame:1个
轮子wheel:4个

四、优点和缺点

优点如下:

1、将一个复杂对象的创建过程封装起来。

2、解耦了组装过程和创建具体部件,使得我们不用去关心每个部件是如何组装的。--上面对自行车的分析可以很清楚的看出这点。

3、向客户隐藏产品内部的表现。

4、产品的实现可以被替换,因为客户只看到一个抽象的接口。

缺点如下:

1、经常被用来创建组合结构。

五、适用性

1、需要生成的产品对象有复杂的内部结构。 2、需要生成的产品对象的属性相互依赖,建造者模式可以强迫生成顺序。 3、在对象创建过程中会使用到系统中的一些其它对象,这些对象在产品对象的创建过程中不易得到。

六、实现要点

1、建造者模式主要用于“分步骤构建一个复杂的对象”,在这其中“分步骤”是一个稳定的算法,而复杂对象的各个部分则经常变化。

2、产品不需要抽象类,特别是由于创建对象的算法复杂而导致使用此模式的情况下或者此模式应用于产品的生成过程,其最终结果可能差异很大,不大可能提炼出一个抽象产品类。 3、创建者中的创建子部件的接口方法不是抽象方法而是空方法,不进行任何操作,具体的创建者只需要覆盖需要的方法就可以,但是这也不是绝对的,特别是类似文本转换这种情况下,缺省的方法将输入原封不动的输出是合理的缺省操作。

4、前面我们说过的抽象工厂模式(AbtractFactory)解决“系列对象”的需求变化,Builder模式解决“对象部分”的需求变化,建造者模式常和组合模式(Composite Pattern)结合使用。

最新文章

  1. 关于Xcode8.1 / iOS10+ 真机测试系统打印或者宏定义打印不显示问题
  2. DIY一个前端模板引擎.(一)
  3. C#基础03
  4. 【PHP面向对象(OOP)编程入门教程】11.类的继承
  5. CentOS 6.5安装Apache
  6. CSS3_loading效果
  7. hdu 1050 (preinitilization or postcleansing, std::fill) 分类: hdoj 2015-06-18 11:33 34人阅读 评论(0) 收藏
  8. Mac OS环境下媒体文件分割工具mediafilesegmenter的简单使用(生成M3U8 TS文件)
  9. 去掉eclipse js 错误提示
  10. jQuery on()方法绑定动态元素的点击事件无效
  11. finger用户名、主目录、停滞时间、登录时间
  12. YII 1.0模型标签与验证规则,前后台验证
  13. java初阶
  14. 浅谈Java中的equals和==与hashCode
  15. Xcode7.2使用sqlite3数据库的方法
  16. 前端入门6-JavaScript客户端api&jQuery
  17. zabbix-2.4.5的安装配置与使用
  18. button theme
  19. poj 3415 Common Substrings - 后缀数组 - 二分答案 - 单调栈
  20. JMeter Sampler之BeanShellSampler的使用

热门文章

  1. WebView 加载网页返回后,jsp界面数据消失(一个斜杆引起来的风波)
  2. Nodejs this详解
  3. ROW_NUMBER() OVER(PARTITION BY ORDER BY )RN 只选一行
  4. LeetCode解题思路
  5. poj1019(打表预处理+数学)
  6. laravel中的模型关联之(一对多)
  7. Unity2017五子棋大战_人机_双人_UNET联网
  8. Java之成员访问控制
  9. 联想G510安装win7系统
  10. how2j网站前端项目——天猫前端(第一次)学习笔记5