设计模式4、建造者模式 Builder

解释说明:将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示
UML 结构图:
抽象建造者(Builder):这个接口规定要实现复杂对象的那些部分的创建,并不设计具体部件对象的创建
具体建造者(ConcreteBuilder):实现 Builder 的接口,完成复杂产品的各个部件的具体创建方法。在构造过程完成后,提供产品的实例
产品(Product):要创建的复杂对象
指挥者(Director):调用具体建造者来创建复杂对象的各个部分,在指导者中不涉及具体产品的信息,只负责保证对象各部分完整创建或按照某种顺序创建
优点:
建造者独立,易于扩展
便于控制细节风险
缺点:
产品必须有共同点,范围有限制
如果内部变化复杂,将会有很多的建造类
适用场景
需要生成的对象具有复杂的内部结构
需要生成的对象内部属性本身相互依赖
考虑这样一个场景,如下图:
Jungle想要建造一栋简易的房子(地板、墙和天花板),两个工程师带着各自的方案找上门来,直接给Jungle看方案和效果图。犹豫再三,Jungle最终选定了一位工程师……交房之日,Jungle满意的看着建好的房子,开始思考:这房子究竟是怎么建成的呢?这地板、墙和天花板是怎么建造的呢?工程师笑着说:“It's none of your business”
#pragma once
#include <iostream>
using namespace std;
// 电脑
class Computer
{
public:void SetmCpu(string cpu) { m_strCpu = cpu; }void SetmMainboard(string mainboard) { m_strMainboard = mainboard; }void SetmRam(string ram) { m_strRam = ram; }void SetVideoCard(string videoCard) { m_strVideoCard = videoCard; }string GetCPU() { return m_strCpu; }string GetMainboard() { return m_strMainboard; }string GetRam() { return m_strRam; }string GetVideoCard() { return m_strVideoCard; }
private:string m_strCpu;  // CPUstring m_strMainboard;  // 主板string m_strRam;  // 内存string m_strVideoCard;  // 显卡
};#include "product.h"
/****建造者模式 Builder******/
// 建造者接口,组装流程
class IBuilder
{
public:virtual void BuildCpu() = 0;  // 创建 CPUvirtual void BuildMainboard() = 0;  // 创建主板virtual void BuildRam() = 0;  // 创建内存virtual void BuildVideoCard() = 0;  // 创建显卡virtual Computer* GetResult() = 0;  // 获取建造后的产品
};
// ThinkPad 系列
class ThinkPadBuilder : public IBuilder
{
public:ThinkPadBuilder() { m_pComputer = new Computer(); }void BuildCpu() { m_pComputer->SetmCpu("i5-6200U"); }void BuildMainboard() { m_pComputer->SetmMainboard("Intel DH57DD"); }void BuildRam() { m_pComputer->SetmRam("DDR4"); }void BuildVideoCard() { m_pComputer->SetVideoCard("NVIDIA Geforce 920MX"); }Computer* GetResult() { return m_pComputer; }
private:Computer* m_pComputer;
};
// Yoga 系列
class YogaBuilder : public IBuilder
{
public:YogaBuilder() { m_pComputer = new Computer(); }void BuildCpu() { m_pComputer->SetmCpu("i7-7500U"); }void BuildMainboard() { m_pComputer->SetmMainboard("Intel DP55KG"); }void BuildRam() { m_pComputer->SetmRam("DDR5"); }void BuildVideoCard() { m_pComputer->SetVideoCard("NVIDIA GeForce 940MX"); }Computer* GetResult() { return m_pComputer; }
private:Computer* m_pComputer;
};#include "builder.h"
// 构造指挥官
class Direcror
{
public:void Create(IBuilder* builder) {builder->BuildCpu();builder->BuildMainboard();builder->BuildRam();builder->BuildVideoCard();}
};#include "builder.h"
#include "director.h"
#include <string>
#ifndef SAFE_DELETE
#define SAFE_DELETE(p) { if(p){delete(p); (p)=NULL;} }
#endif
int main()
{Direcror* pDirecror = new Direcror();ThinkPadBuilder* pTPBuilder = new ThinkPadBuilder();YogaBuilder* pYogaBuilder = new YogaBuilder();// 组装 ThinkPad、YogapDirecror->Create(pTPBuilder);pDirecror->Create(pYogaBuilder);// 获取组装后的电脑Computer* pThinkPadComputer = pTPBuilder->GetResult();Computer* pYogaComputer = pYogaBuilder->GetResult();// 测试输出cout << "-----ThinkPad-----" << endl;cout << "CPU: " << pThinkPadComputer->GetCPU() << endl;cout << "Mainboard: " << pThinkPadComputer->GetMainboard() << endl;cout << "Ram: " << pThinkPadComputer->GetRam() << endl;cout << "VideoCard: " << pThinkPadComputer->GetVideoCard() << endl;cout << "-----Yoga-----" << endl;cout << "CPU: " << pYogaComputer->GetCPU() << endl;cout << "Mainboard: " << pYogaComputer->GetMainboard() << endl;cout << "Ram: " << pYogaComputer->GetRam() << endl;cout << "VideoCard: " << pYogaComputer->GetVideoCard() << endl;SAFE_DELETE(pThinkPadComputer);SAFE_DELETE(pYogaComputer);SAFE_DELETE(pTPBuilder);SAFE_DELETE(pYogaBuilder);SAFE_DELETE(pDirecror);getchar();return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/120614.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RV1126笔记四十一:RV1126移植LIVE555

若该文为原创文章,转载请注明原文出处。 RV1126的SDK有提供了一个librtsp.a封装好的RTSP推流库,但不开源,还有个确定延时长,所以想自己写一个RTSP的推流,但不想太麻烦,所以使用Live555。 记录下移植过程和测试结果。 live555需要用到的包有 openssl 和live555 一、 编…

Linux 进程层次分析

Linux 进程组 每个进程都有一个进程组号 (PGID) 进程组&#xff1a;一个或多个进程的集合 (集合中的进程并不孤立)进程组中的进程通常存在父子关系&#xff0c;兄弟关系&#xff0c;或功能相近 进程组可方便进程管理 (如&#xff1a;同时杀死多个进程&#xff0c;发送一个信…

阿里云七代云服务器实例、倚天云服务器及通用算力型和经济型实例规格介绍

在目前阿里云的云服务器产品中&#xff0c;既有五代六代实例规格&#xff0c;也有七代和八代倚天云服务器&#xff0c;同时还有通用算力型及经济型这些刚推出不久的新品云服务器实例&#xff0c;其中第五代实例规格目前不在是主推的实例规格了&#xff0c;现在主售的实例规格是…

【C++进阶(六)】STL大法--栈和队列深度剖析优先级队列适配器原理

&#x1f493;博主CSDN主页:杭电码农-NEO&#x1f493;   ⏩专栏分类:C从入门到精通⏪   &#x1f69a;代码仓库:NEO的学习日记&#x1f69a;   &#x1f339;关注我&#x1faf5;带你学习C   &#x1f51d;&#x1f51d; 栈和队列 1. 前言2. 栈和队列的接口函数熟悉3. …

Java基础面试题精选:深入探讨哈希表、链表和接口等

目录 1.ArrayList和LinkedList有什么区别&#xff1f;&#x1f512; 2.ArrayList和Vector有什么区别&#xff1f;&#x1f512; 3.抽象类和普通类有什么区别&#xff1f;&#x1f512; 4.抽象类和接口有什么区别&#xff1f;&#x1f512; 5.HashMap和Hashtable有什么区别&…

[C++ 网络协议] 异步通知I/O模型

1.什么是异步通知I/O模型 如图是同步I/O函数的调用时间流&#xff1a; 如图是异步I/O函数的调用时间流&#xff1a; 可以看出&#xff0c;同异步的差别主要是在时间流上的不一致。select属于同步I/O模型。epoll不确定是不是属于异步I/O模型&#xff0c;这个在概念上有些混乱&a…

基于TOTP算法的Github两步验证2FA(双因子)机制Python3.10实现

从今年(2023)三月份开始&#xff0c;Github开始强制用户开启两步验证2FA(双因子)登录验证&#xff0c;毫无疑问&#xff0c;是出于安全层面的考虑&#xff0c;毕竟Github账号一旦被盗&#xff0c;所有代码仓库都会毁于一旦&#xff0c;关于双因子登录的必要性请参见&#xff1a…

(三)Python变量类型和运算符

所有的编程语言都支持变量&#xff0c;Python 也不例外。变量是编程的起点&#xff0c;程序需要将数据存储到变量中。 变量在 Python 内部是有类型的&#xff0c;比如 int、float 等&#xff0c;但是我们在编程时无需关注变量类型&#xff0c;所有的变量都无需提前声明&#x…

快速将iPhone大量照片快速传输到电脑的办法!

很多使用iPhone 的朋友要将照片传到电脑时&#xff0c;第一时间都只想到用iTunes 或iCloud&#xff0c;但这2个工具真的都非常难用&#xff0c;今天小编分享牛学长苹果数据管理工具的照片传输功能&#xff0c;他可以快速的将iPhone照片传输到电脑上&#xff0c;并且支持最新的i…

C语言实现——简易通讯录

前言&#xff1a;小伙伴们又见面啦&#xff01;这几天通过我们对自定义数据类型的学习&#xff0c;我们已经掌握了如何同时对多种数据类型进行管理&#xff0c;那么今天这篇文章&#xff0c;我们就来干一件大事——实现简易的通讯录。 一.思路分析 先来想想通讯录有哪些功能&a…

Python 爬虫 / web 面试常见问题

嗨喽&#xff0c;大家好呀~这里是爱看美女的茜茜呐 &#x1f447; &#x1f447; &#x1f447; 更多精彩机密、教程&#xff0c;尽在下方&#xff0c;赶紧点击了解吧~ python源码、视频教程、插件安装教程、资料我都准备好了&#xff0c;直接在文末名片自取就可 爬虫面试常见…

No145.精选前端面试题,享受每天的挑战和学习

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6 🍨 阿珊和她的猫_CSDN个人主页 🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入…