Builder模式

原创 2015年07月10日 19:03:01

Builder模式

Builder模式要解决的问题是把对象的构建和对象的表示分开来。当对象复杂的时候我,我们可以一步步来构建对象,在每一步的构建过程中,可以引入参数,通过不同的参数,即使经过相同的步骤最后可以得到不同的对象。

通过一个实例来说明,Product是我们要构建的对象,在Builder类中构建,通过BuildPartA、BuildPartB、BuildPartC三步来构建对象,一个ConcreteBuilder类来具体实现Builder类,通过Director类来调用Builder类指导构建过程。

下图是Builder模式的类结构图。
这里写图片描述

//Product.h



#ifndef _PRODUCT_H
#define _PRODUCT_H
class Product
{
public:
    Product();
    ~Product();
    void ProductPart();
protected:

private:

};

class ProductPart
{
public:
    ProductPart();
    ~ProductPart();

    ProductPart* BuildPart();

protected:

private:

};

#endif

//Product.cpp

#include"Product.h"

#include<iostream>

Product::Product()
{
    std::cout << "Product Ctor" << std::endl;
}

Product::~Product()
{
    std::cout << "Product Dtor" << std::endl;
}

void Product::ProductPart()
{

}

ProductPart::ProductPart()
{
    std::cout << "ProductPart Cotr" << std::endl;
}
ProductPart::~ProductPart()
{
    std::cout << "ProductPart Dtor" << std::endl;
}
ProductPart* ProductPart::BuildPart()
{
    return NULL;
}

//Builder.h

//Builder.cpp

#include"Builder.h"
#include"Product.h"
#include<iostream>
using namespace std;

Builder::Builder()
{

}
Builder::~Builder()
{

}

ConcreteBuilder::ConcreteBuilder()
{

}
ConcreteBuilder::~ConcreteBuilder()
{

}
void ConcreteBuilder::BuildPartA(const string& buildPara)
{
    cout << "Step1: Build PartA..." << buildPara << endl;
}
void ConcreteBuilder::BuildPartB(const string& buildPara)
{
    cout << "Step2: Build PartB..." << buildPara << endl;
}
void ConcreteBuilder::BuildPartC(const string& buildPara)
{
    cout << "Step3: Build PartC..." << buildPara << endl;
}
Product* ConcreteBuilder::GetProduct()
{
    BuildPartA("pre-define");
    BuildPartB("pre-define");
    BuildPartC("pre-define");
    return new Product();

}

//Director.h

//Director.h

#ifndef _DIRECTOR_H_
#define _DIRECTOR_H_
class Builder;
class Director
{
public:
    Director(Builder* bld);
    ~Director();
    void Construct();
protected:
private:
    Builder* _bld;
};


#endif

//Director.cpp


//Director.cpp

#include"Director.h"
#include"Builder.h"

Director::Director(Builder* bld)
{
    _bld = bld;
}
Director::~Director()
{

}

void Director::Construct()
{
    _bld->BuildPartA("user-define");
    _bld->BuildPartB("user-define");
    _bld->BuildPartC("user-define");

}

//main.cpp

//main.cpp

#include"Builder.h"
#include"Product.h"
#include"Director.h"
#include<iostream>

int main(int agrc, char* agrv[])
{
    Director* d = new Director(new ConcreteBuilder());
    d->Construct();

    return 0;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Builder模式

  • 2013-01-11 14:05
  • 237KB
  • 下载

1.2 Builder(生成器) -- 对象创建型模式

在内蒙古这辽阔的草原上,放养着成千上万的奶牛。蒙牛集团在这里崛起,迅速抢占中国大半牛奶市场,造就了一个商业帝国。蒙牛集团牛奶生产流程大致是这样的: 放养奶牛--->牛奶加工--->牛奶包装--->销售...

Android 建造者(Builder)模式

关于 Builder 模式 详述:http://blog.csdn.net/jjwwmlp456/article/details/39890699 先来张图    看到 Android  中 使用...

Builder模式Demo

  • 2017-05-05 16:06
  • 22.38MB
  • 下载

建造者模式-Builder Pattern

基本概念 建造者模式将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示,又叫做生成器模式。建造者模式将一个产品的内部表象与产品的生产过程分割开来,从而可以使一个建造过程生成具有不...

晨会分享Builder设计模式

  • 2016-08-02 00:31
  • 297KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)