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

适用性:1.当创建复杂对象的算法应该独立于该对象的组成部分以及它们的装配方式时。

    2.当构建过程必须允许被构建的对象有不同的表示时。

效果:   1.使得可以改变一个产品的内部表示。

    2.隐藏产品的内部结构。

    3.使得构造代码和表示代码分离。

    4.使得可以对构建过程进行更精确的控制。

代码实例:

代码以构建Room为实例,而Room由四个Site组成,Site可以是Wall、Window、Door、Grass、Wood。(其中

wood和grass分别表示木制墙和玻璃墙). 这里Room可以有3 Wall  1 Door 或 2 wall 1 Door 1 Window等各种

表示。构建在具体Builder中实现,而在Director中表示,体现了效果3.

在Builder头文件下,首先我们创建各种要用到的类:

 #ifndef _BUILDER_
#define _BUILDER_
#include <string>
#include <iostream>
using namespace std;
const int MAXSITE = ; class Site{
public:
Site(string str):_mName(str){}
string _mName;
}; class Wall:public Site{
public:
Wall():Site("wall"){}
}; class Wood:public Site{
public:
Wood():Site("wood"){}
}; class Grass:public Site{
public:
Grass():Site("grass"){}
}; class Door:public Site{
public:
Door():Site("door"){}
}; class Window:public Site{
public:
Window():Site("window"){}
}; class Room{
public:
Room(){
for(int i = ; i < MAXSITE; i++)
_mSite[i] = NULL;
}
void Printf()
{
for(int i = ; i < MAXSITE; i++)
{
if(_mSite[i] != NULL)
cout<<_mSite[i]->_mName<<endl;
}
}
Site* _mSite[MAXSITE];
};

要用到的类

接着我们创建AbsBuilder,这里提供给向导器一个构造产品的抽象接口。因为不知道具体哪个类被创建并用于组成目标类,所以达到了效果2.

class AbsBuilder{
public:
AbsBuilder(){} virtual void BuilderWall(){}
virtual void BuilderDoor(){}
virtual void BuilderWindow(){}
virtual void BuilderGrass(){}
virtual void BuilderWood(){} virtual Room* GetRoom() = ;
};

然后是具体创建BuilderA/B...,体现了可以改变产品的内部表示(效果1.)

class BuilderA:public AbsBuilder{

public:
BuilderA():_mNum(){_mpRoom = new Room; } virtual void BuilderWall(){_mpRoom->_mSite[_mNum++] = new Wall;}
virtual void BuilderDoor(){_mpRoom->_mSite[_mNum++] = new Door;}
virtual void BuilderWindow()
{
_mpRoom->_mSite[_mNum++] = new Window;
_mpRoom->_mSite[_mNum++] = new Window;
} virtual Room* GetRoom(){return _mpRoom; }
private:
Room* _mpRoom;
int _mNum;
}; class BuilderB:public AbsBuilder{ public:
BuilderB():_mNum(){_mpRoom = new Room; }
virtual void BuilderWood(){_mpRoom->_mSite[_mNum++] = new Wood;}
virtual void BuilderDoor(){_mpRoom->_mSite[_mNum++] = new Door;}
virtual void BuilderWindow()
{
_mpRoom->_mSite[_mNum++] = new Grass;
_mpRoom->_mSite[_mNum++] = new Grass;
} virtual Room* GetRoom(){return _mpRoom; }
private:
Room* _mpRoom;
int _mNum;
}; #endif

BuilderA/B

在Director头文件下,创建类Director. 因为这里一步步构造产品,体现了效果4.

class Director{
public:
Director(AbsBuilder* builder){_mBuilder = builder;}
void construct()
{
_mBuilder->BuilderDoor();
_mBuilder->BuilderWall();
_mBuilder->BuilderWindow();
_mBuilder->BuilderGrass();
_mBuilder->BuilderWood();
}
private:
AbsBuilder* _mBuilder;
};

main函数中:

#include <iostream>
using namespace std; #include "Builder.h"
#include "Director.h" int main()
{
BuilderA* pBuilderA = new BuilderA;
Director directro(pBuilderA);
directro.construct();
Room* roomA = pBuilderA->GetRoom();
roomA->Printf(); cout<<endl; BuilderB* pBuilderB = new BuilderB;
Director directroB(pBuilderB);
directroB.construct();
Room* roomB = pBuilderB->GetRoom();
roomB->Printf(); cout<<endl;
return ;
}

生成器模式(Builder)C++实现的更多相关文章

  1. 第9月第6天 push pop动画 生成器模式(BUILDER)

    1. https://github.com/MichaelHuyp/QQNews 2.生成器模式(BUILDER) class MazeBuilder { public: virtual void B ...

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

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

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

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

  4. 跟着实例学习设计模式(6)-生成器模式builder(创建型)

    生成器模式是创建型设计模式. 设计意图:将一个复杂的类表示与其构造相分离,使得同样的构建过程可以得出不同的表示. 实例类图: IVehicleBuilder:抽象建造者.为创建一个Vehicle对象并 ...

  5. 生成器模式Builder

    原创转载请注明出处:https://www.cnblogs.com/agilestyle/p/11406502.html 1. 定义将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的 ...

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

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

  7. 1.6建造者模式(生成器模式) Builder

    1.概念:将一个复杂对象的构建和他的表示分离,使得同样的构件可以创建不同的表示. 2.实例:肯德基和中餐,肯德基抽象了整个做菜的复杂过程(相同的构建),然后在不同的店铺进行实现(不同的表示).中餐往往 ...

  8. 生成器模式(Builder)

    1.本质:分离整体构建算法和部分构造 2.示意图: 3.功能: 构建复杂的产品,而且是细化的.分步骤的构建产品 分离构建算法和具体的构建实现 具体的构造实现可以方便的切换和扩展 4.优点: 1.松散耦 ...

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

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

随机推荐

  1. CentOS安装Docker-ce并配置国内镜像

    前提条件 1.系统.内核 CentOS7 要求64位系统.内核版本3.10以上 CentOS6 要求版本在6.5以上,系统64位.内核版本2.6.32-431以上 查看内核版本号 uname -r # ...

  2. 面向对象:__getitem__、__setitem__、__delitem__

    item系列 class Person(object): def __init__(self, name): self.name = name def __getitem__(self, item): ...

  3. Asp.NET误人子弟教程:在MVC里面结合JQ实现AJAX

    public class Person { public string Name { get; set; } public string City { get; set; } public strin ...

  4. Leetcode 39.组合总数

    组合总数 给定一个无重复元素的数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合. candidates 中的数字可以无限 ...

  5. Jzzhu and Numbers

    Jzzhu and Numbers time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...

  6. 同余方程 2012年NOIP全国联赛提高组

    时间限制: 1 s   空间限制: 128000 KB 题目描述 Description 求关于 x 同余方程 ax ≡ 1 (mod b)的最小正整数解. 输入描述 Input Descriptio ...

  7. springCloud学习-服务的注册与发现(Eureka)

    1.小记 这段时间有空,把springcloud的知识整理一下,好记性不如烂笔头,也让自己对springcloud有个清晰的认识.此次的整理记录主要借鉴了这位大佬的博客 https://blog.cs ...

  8. 用R语言 画条形图(基于ggplot2包)

    1.用qplot(x,data=data,geom.=”bar”,weight=y)+scale_y_continuous("y")画出y关于x的条形. 图中提示binwidth这 ...

  9. cocoa 运行apple脚本文件的方法

    NSString* path = [[NSBundle mainBundle] pathForResource:@"ScriptName" ofType:@"scpt&q ...

  10. sql server使用杂记

    SqlServer导出数据库 navcat for sql server中打开连接,打开数据库,右键--数据传输,常规选项卡--模式选择dbo,目标选择连接(选择你新建的库)或者文件(导出你要的sql ...