设计模式-Builder模式(创建型模式)
//以下代码来源: 设计模式精解-GoF 23种设计模式解析附C++实现源码
//Product.h
#pragma once
class Product {
public:
Product();
~Product();
void ProducePart();
protected:
private:
}; class ProductPart {
public:
ProductPart();
~ProductPart();
ProductPart* buildPart();
protected:
private: };
//Product.cpp
#include"Product.h"
#include<iostream> Product::Product()
{
ProducePart();
std::cout << "return a Product." << std::endl;
}
Product::~Product()
{ }
void Product::ProducePart()
{
std::cout << "Build part of product." << std::endl;
} ProductPart::ProductPart(){}
ProductPart::~ProductPart(){}
ProductPart* ProductPart::buildPart()
{
return new ProductPart;
}
//Build.h
#pragma once
#include<string>
class Product;
class Builder {
public:
virtual ~Builder();
virtual void BuildPartA(const std::string& buildPara) = ;
virtual void BuildPartB(const std::string& buildPara) = ;
virtual void BuildPartC(const std::string& buildPara) = ;
virtual Product* getProduct() = ;
protected:
Builder();
private:
}; class ConcreateBuilder :public Builder {
public:
ConcreateBuilder();
virtual ~ConcreateBuilder();
void BuildPartA(const std::string& buildPara);
void BuildPartB(const std::string& buildPara);
void BuildPartC(const std::string& buildPara);
Product* getProduct();
protected:
private:
};
//Build.cpp
#include"Build.h"
#include"Product.h"
#include<iostream> Builder::Builder(){}
Builder::~Builder(){}
ConcreateBuilder::ConcreateBuilder(){}
ConcreateBuilder::~ConcreateBuilder(){}
void ConcreateBuilder::BuildPartA(const std::string& buildPara)
{
std::cout << "Step1: Build Part1...." << buildPara << std::endl;
}
void ConcreateBuilder::BuildPartB(const std::string& buildPara)
{
std::cout << "Step2: Build Part2..." << buildPara << std::endl;
}
void ConcreateBuilder::BuildPartC(const std::string& buildPara)
{
std::cout << "Step3: Build Part3..." << buildPara << std::endl;
}
Product* ConcreateBuilder::getProduct()
{
BuildPartA("Pre-Defined");
BuildPartB("Pre-Defined");
BuildPartC("Pre-Defined");
return new Product();
}
//Director.h
#pragma once
class Builder;
class Director {
public:
~Director();
Director(Builder* bld);
void Construct();
protected:
private:
Builder* _bld;
};
//Director.cpp
#include"Director.h"
#include"Build.h" Director::~Director()
{ }
Director::Director(Builder* bld)
{
_bld = bld;
}
void Director::Construct()
{
_bld->BuildPartA("User-Defined");
_bld->BuildPartB("User-Defined");
_bld->BuildPartC("User-Defined");
}
//main.cpp
#include"Build.h"
#include"Director.h"
#include"Product.h" int main(int args, char* argv)
{
Director* dir = new Director(new ConcreateBuilder());
dir->Construct(); return ;
}
设计模式-Builder模式(创建型模式)的更多相关文章
- Java经典设计模式之五大创建型模式(附实例和详解)
一.概况 总体来说设计模式分为三大类: (1)创建型模式,共五种:工厂方法模式.抽象工厂模式.单例模式.建造者模式.原型模式. (2)结构型模式,共七种:适配器模式.装饰器模式.代理模式.外观模式.桥 ...
- 初探Java设计模式1:创建型模式(工厂,单例等)
Java 设计模式 一直想写一篇介绍设计模式的文章,让读者可以很快看完,而且一看就懂,看懂就会用,同时不会将各个模式搞混.自认为本文还是写得不错的,花了不少心思来写这文章和做图,力求让读者真的能看着简 ...
- Java设计模式之五大创建型模式(附实例和详解)
一.概况 总体来说设计模式分为三大类: (1)创建型模式,共五种:工厂方法模式.抽象工厂模式.单例模式.建造者模式.原型模式. (2)结构型模式,共七种:适配器模式.装饰器模式.代理模式.外观模式.桥 ...
- Builder生成器(创建型模式)
一.使用场景: 1.假设要创建一个House设施,该设施的创建由若干个部分组成,而且这若干个部分经常变化. 如果用最直观的设计方式,每一个房屋部分的变化,都将导致整个房屋结构的重新修正,但是这种设计方 ...
- Java经典设计模式之五大创建型模式
转载: Java经典设计模式之五大创建型模式 一.概况 总体来说设计模式分为三大类: (1)创建型模式,共五种:工厂方法模式.抽象工厂模式.单例模式.建造者模式.原型模式. (2)结构型模式,共七种: ...
- FactoryMethod工厂方法模式(创建型模式)
1.工厂方法模式解决的问题 现在有一个抽象的游戏设施建造系统,负责构建一个现代风格和古典风格的房屋和道路. 前提:抽象变化较慢,实现变化较快(不稳定) 整个抽象的游戏设施建造系统相对变化较慢,本例中只 ...
- Prototype原型模式(创建型模式)
1.原型模式解决的问题 现在有一个抽象的游戏设施建造系统,负责构建一个现代风格和古典风格的房屋和道路. 前提:抽象变化较慢,实现变化较快(不稳定) 整个抽象的游戏设施建造系统相对变化较慢,本例中只有一 ...
- 设计模式(二): BUILDER生成器模式 -- 创建型模式
1.定义 将一个复杂对象的构造与它的表示分离,使同样的构建过程可以创建不同的表示,这样的设计模式被称为建造者模式. 2.适用场景 1. 当创建复杂对象的算法应该独立于该对象的组成部分以及它们的装配方式 ...
- NET设计模式 第二部分 创建型模式(6):创建型模式专题总结(Creational Pattern)
创建型模式专题总结(Creational Pattern) ——.NET设计模式系列之七 Terrylee,2006年1月 概述 创建型模式,就是用来创建对象的模式,抽象了实例化的过程.它帮助一个系统 ...
- 设计模式(五):PROTOTYPE原型模式 -- 创建型模式
1.定义 用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象. 2.适用场景 原型模式的主要思想是基于现有的对象克隆一个新的对象出来,一般是有对象的内部提供克隆的方法,通过该方法返回一个对 ...
随机推荐
- python直接赋值、浅拷贝、深拷贝的区别
一:直接赋值 赋值,就是对象的引用,给对象起别名. i = 8j = iprint("值是:",i, "地址:",id(i))print("值是:&q ...
- Java之Random类
什么是Random类 此类的实例用于生成伪随机数,使用此类中的方法能够得到一个随机数. Random使用步骤 查看类 java.util.Random :该类需要 import导入使后使用. 查看构造 ...
- Educational Codeforces Round 76 (Rated for Div. 2) E. The Contest dp
E. The Contest A team of three programmers is going to play a contest. The contest consists of
- nodejs的require是如何执行的
通常,在Node.js里导入是通过 require函数调用进行的. Node.js会根据 require的是相对路径还是非相对路径做出不同的行为. 相对路径 相对路径很简单. 例如,假设有一个文件路径 ...
- Java连载49-常量格式、package包介绍
一.常量 1.常量的定义:final修饰的实例变量是不可变的,这种变量一般和static联合使用,被称为“常量” 2.常量的语法格式: public static final 类型 常量名 = 值: ...
- Vue之外的杂谈笔记
1.老项目的构建输出为什么臃肿? 引用:(引自http://www.cnblogs.com/linfangshuhellowored/p/5657285.html) 答:因为使用的是require的r ...
- 在Vue中使用i18n 国际化遇到 Uncaught TypeError: Cannot assign to read only property 'exports' of object '#<Object>'
最近用Vue在搭建前端框架,在引用i18n时,运行的时候报错:Uncaught TypeError: Cannot assign to read only property 'exports' of ...
- Ganglia+Nagios监控系统
第1章 简介 ganglia是一款为HPC(高性能计算) 集群设计的可扩展性 的分布式监控系统,它可以监视和显示集群中节点的各种状态信息,他由运行在各个节点上的gmond守护进程来采集 CPU.内存. ...
- Linux域名服务DNS
什么是 DNS DNS 全称是 Domain Name System,大意是域名解析系统,它的职责是把域名翻译成一个一个可以识别的 IP 供不同的计算机设备连接. linux 有关 DNS 解析的配置 ...
- Python用python-docx读写word文档
python-docx库可用于创建和编辑Microsoft Word(.docx)文件.官方文档:https://python-docx.readthedocs.io/en/latest/index. ...