简介

生成器模式属于创建型模式的一种, 又叫建造者模式.

生成器模式涉及4个关键角色:产品(Product),抽象生成器(builder),具体生成器(ConcreteBuilder),指挥者(Director).

实现层面上, 产品定义了需要什么样的对象, 具体生成器完成了对象的具体表示. 如果只需要一个具体的构建者,那么抽象生成器角色和指挥者可以省略(如StringBuilder).

意图

将一个复杂对象的构建与它的表示分离, 使得同样的构建过程可以创建不同的表示.

类图

实现

一. 定义产品

/**
* Car 有很多成员变量, 当然成员可能是一些复杂类型, 这里简化只定义一些基本类型
*/
@Data
public class Car {
private String engine; //发动机
private String chassis; // 底盘
private String body; //车身
private String wheels; //轮子
private String equipment; //构件, 可选
private String radar;// 雷达, 可选
}

二. 定义抽象生成器角色

/**
* 抽象生成器角色,定义每个组件的创建返回类型为本类型, 这样就可以使用链式编程方式了
* 定义了返回最终产品的接口
*/
public abstract class AbstractCarBuilder { //产品
private Car car = new Car(); protected Car getCar(){
return car;
} public abstract AbstractCarBuilder setEngine();
public abstract AbstractCarBuilder setChassis();
public abstract AbstractCarBuilder setBody();
public abstract AbstractCarBuilder setWheels();
public abstract AbstractCarBuilder setEquipment();
public abstract AbstractCarBuilder setRadar(); // 返回产品
public Car build(){
return car;
}
}

三. 定义具体的生成器实现,这里定义两个

// 第一个实现
public class BMWCarBuilder extends AbstractCarBuilder { public AbstractCarBuilder setEngine() {
Car car = this.getCar();
car.setEngine("BMW setEngine");
return this;
} public AbstractCarBuilder setChassis() {
Car car = this.getCar();
car.setChassis("BMW setChassis");
return this;
} public AbstractCarBuilder setBody() {
Car car = this.getCar();
car.setBody("BMW setBody");
return this;
} public AbstractCarBuilder setWheels() {
Car car = this.getCar();
car.setWheels("BMW setWheels");
return this;
} public AbstractCarBuilder setEquipment() {
Car car = this.getCar();
car.setEquipment("BMW setEquipment");
return this;
} public AbstractCarBuilder setRadar() {
Car car = this.getCar();
car.setRadar("BMW setRadar");
return this;
}
}
//第二个实现
public class QQCarBuilder extends AbstractCarBuilder {
public AbstractCarBuilder setEngine() {
Car car = this.getCar();
car.setEngine("QQ setEngine");
return this;
} public AbstractCarBuilder setChassis() {
Car car = this.getCar();
car.setChassis("QQ setChassis");
return this;
} public AbstractCarBuilder setBody() {
Car car = this.getCar();
car.setBody("QQ setBody");
return this;
} public AbstractCarBuilder setWheels() {
Car car = this.getCar();
car.setWheels("QQ setWheels");
return this;
} //没有此组件, 不做任何事情
public AbstractCarBuilder setEquipment() {
return this;
} //没有此组件, 不做任何事情
public AbstractCarBuilder setRadar() {
return this;
}
}

四. 定义指挥者

/**
* 指挥者角色, 用来定义构建复杂对象的算法
* 这里同时也定义了测试的main方法
*/
public class Director { private AbstractCarBuilder builder; public Director(AbstractCarBuilder builder) {
this.builder = builder;
} public Car BuildCar(){
// 链式构建,并返回最终的结果
return builder
.setWheels()
.setRadar()
.setEngine()
.setChassis()
.setBody()
.setEquipment()
.build();
} public static void main(String[] args) {
Director director = new Director(new QQCarBuilder());
Car car = director.BuildCar();
System.out.println(car.toString()); director = new Director(new BMWCarBuilder());
car = director.BuildCar();
System.out.println(car.toString());
} }

总结

如果一个对象需要的成员变量较多, 也就是初始化所需参数过多, 过程比较复杂的话, 那么它就适合使用Builder模式.

优点: 对象分解为组件;将对象构造封装;构造过程可控;

缺点: 增加了类的数量.

与抽象工厂模式的区别: 二者都可以创建复杂对象, 不同的是抽象工厂强调创建一系列的产品对象, 而生成器模式着重于一步步创建一个复杂对象. Builder模式的对象是最后返回的, 抽象工厂的产品是立即返回.

设计模式十: 生成器模式(Builder Pattern)的更多相关文章

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

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

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

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

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

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

  4. C#设计模式——生成器模式(Builder Pattern)

    一.概述在软件系统中,有时候面临着复杂的对象创建,该对象由一定算法构成的子对象组成,由于需求变化,这些子对象会经常变换,但组合在一起的算法却是稳定的.生成器模式可以处理这类对象的构建,它提供了一种封装 ...

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

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

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

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

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

    概述 描述 建造者模式,又称生成器模式.是将一个复杂的对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示. 建造者模式将客户端与包含多个组成部分的复杂对象的创建过程分离,客户端无需知道复杂 ...

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

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

  9. 浅谈设计模式--建造器模式(Builder Pattern)

    建造器模式,是于创建带有大量参数的对象,并避免因参数数量多而产生的一些问题(如状态不一致-JavaBean的setter模式). 如果参数多且有些是必须初始化的,有些是不一定需要初始化的时候,创建对象 ...

随机推荐

  1. D. Concatenated Multiples(离线处理)

    思路:直接离线处理出每个ai 的10倍, 100倍, 1000倍的mod k 后的数值的个数,使用map<int,int >ss[12]存储, ss[x][y]表示 (ai*10x)%k= ...

  2. 步步深入:MySQL架构总览->查询执行流程->SQL解析顺序(转)

    文章转自   http://www.cnblogs.com/annsshadow/p/5037667.html https://www.cnblogs.com/cuisi/p/7685893.html

  3. AI AutoML

    AutoML 参考链接: https://arxiv.org/pdf/1810.13306.pdf http://nooverfit.com/wp/7%E4%B8%AA%E4%BD%A0%E5%8F% ...

  4. 【原创】讲讲亿级PV的负载均衡架构

    引言 本来没想写这个题材的,为了某某童鞋能够更好的茁壮成长,临时写一篇负载均衡的.负载均衡,大家可能听过什么3层负载均衡.4层负载均衡.7层负载均衡什么的?那这是怎么分的呢,ok,是根据osi七层网络 ...

  5. PTA 天梯赛练习 7-11 玩转二叉树-二叉树重建

    以前就思考过这个问题,但是没有深入的想过,这是一种叫二叉树重建的典型题目 如果给出中序和前序,求出后序遍历. 这道题则求的是交换儿子节点的层序遍历. 二叉树的重建应该怎么重建,首先我们知道,先根遍历, ...

  6. PS快速祛除脸上小雀斑

    首先我们要把图片放到PS软件中,然后在PS左侧工具栏中找到污点修复画笔工具(J), 配合着污点修复画笔中的修补工具一起使用,注意:模式要选择正常,属性栏中类型要选择内容识别. 下一步我们需要在图层上添 ...

  7. webpack+vue 组件间传参(单一事件中心管理组件通信--$root),如果有路由的话会失效

    先给一个例子: <body> <div id="box"> <com-a></com-a> <com-b></co ...

  8. 为什么String被设计为不可变?是否真的不可变?

    1 对象不可变定义 不可变对象是指对象的状态在被初始化以后,在整个对象的生命周期内,不可改变. 2 如何不可变 通常情况下,在java中通过以下步骤实现不可变 对于属性不提供设值方法 所有的属性定义为 ...

  9. flask 实现登录 登出 检查登录状态 的两种方法的总结

    这里我是根据两个项目的实际情况做的总结,方法一(来自项目一)的登录用的是用户名(字符串)和密码,前后端不分离,用form表单传递数据:方法二用的是手机号和密码登录,前后端分离,以json格式传递数据, ...

  10. [SimplePlayer] 3. 视频帧同步

    Frame Rate 帧率代表的是每一秒所播放的视频图像数目.通常,视频都会有固定的帧率,具体点地说是每一帧的时间间隔都是一样的,这种情况简称为CFR(Constant Frame Rate);另外一 ...