- 浏览: 373616 次
- 性别:
- 来自: 苏州
文章分类
- 全部博客 (335)
- C++ (190)
- 设计模式 (43)
- 数据库技术 (5)
- 网络编程 (11)
- 自动化测试 (6)
- Linux (13)
- OpenSSL (10)
- MS Crypt API (5)
- SCM (2)
- English (4)
- Android (10)
- EMV规范 (1)
- Saturn Platform (0)
- C (10)
- SQL (2)
- ASP.NET (3)
- 英语口语学习 (3)
- 调试工具 (21)
- 编译技术 (5)
- UML (1)
- 项目管理 (5)
- 敏捷开发 (2)
- Http Server (6)
- 代码审查、代码分析 (5)
- 面试基础 (10)
- 重点知识 (16)
- STL (6)
- Efficient C++资料 (8)
- 数据结构和算法 (7)
- 读书笔记 (0)
- 开源项目 (4)
- 多线程 (2)
- Console App (6)
- 个人开源项目 (4)
- IBM DevelopWorks (4)
- Java (16)
- 内存泄漏相关调试和检测 (13)
- 软件测试相关技术 (2)
- C# (11)
- Apple Related (1)
- 软件测试和管理 (2)
- EMV (1)
- Python (1)
- Node.js (6)
- JavaScript (5)
- VUE (1)
- Frontend (1)
- Backend (4)
- RESTful API (3)
- Firebase (3)
最新评论
-
u013189503:
来个密码吧
[C++][Logging] 项目中写日志模块的实现 -
wyf_vc:
来个密码啊!!
[C++][Logging] 项目中写日志模块的实现
我的理解:
在实际的项目中,很多时候我们和一些设备的沟通都是通过数据流来完成的。用户和设备通过固定格式的包进行处理。实际项目
中使用的一个实例如下:Application Package Format:{CmdCode}{Type}{P1}{P2}{Len}{Data}
这样的一个包具有严格的格式,同时不同参数具有不同的意义,这样一来,就可以理解为一个典型的Builder Pattern。
流程:
用户代表了客户端的行为,所以逻辑如下:
(1)用户连接设备,按照协议,确定数据包的组成,一个完整的数据包其实本质就一个Product;
(2)确定数据包的组成部分之后,我们需要确定各个数据组成的先后顺序(Director);实例中,数据包的顺序是1、2、3、4、5;
但是根据不同的情况,修改成4、1、2、3、5,也是很有可能的;
(3)利用原始的组成数据按照一定顺序组成一个完整的数据包;
头文件
实现
客户端
运行结果
在实际的项目中,很多时候我们和一些设备的沟通都是通过数据流来完成的。用户和设备通过固定格式的包进行处理。实际项目
中使用的一个实例如下:Application Package Format:{CmdCode}{Type}{P1}{P2}{Len}{Data}
这样的一个包具有严格的格式,同时不同参数具有不同的意义,这样一来,就可以理解为一个典型的Builder Pattern。
流程:
用户代表了客户端的行为,所以逻辑如下:
(1)用户连接设备,按照协议,确定数据包的组成,一个完整的数据包其实本质就一个Product;
(2)确定数据包的组成部分之后,我们需要确定各个数据组成的先后顺序(Director);实例中,数据包的顺序是1、2、3、4、5;
但是根据不同的情况,修改成4、1、2、3、5,也是很有可能的;
(3)利用原始的组成数据按照一定顺序组成一个完整的数据包;
头文件
//BuilderPattern.h #ifndef BUILDER_PATTERN_H #define BUILDER_PATTERN_H #include <Windows.h> #include <string> using namespace std; namespace BuilderPattern { class Product { public: Product(); ~Product(); void AddPart(string strPart); string DisplayProduct(); void EmptyParts(); private: string m_strFullParts; }; // Base Class ////////////////////////////////////////////////////////////////////////// class AbstractBuilder { public: AbstractBuilder(); virtual ~AbstractBuilder(); virtual void BuildHead() = 0; virtual void BuildData() = 0; virtual void BuildType() = 0; virtual void BuildP1P1() = 0; virtual void BuildLen() = 0; virtual Product* GetProduct() = 0; }; ////////////////////////////////////////////////////////////////////////// class ConcreteBuilderA : public AbstractBuilder { public: ConcreteBuilderA(Product* pProduct); virtual ~ConcreteBuilderA(); virtual void BuildHead(); virtual void BuildData(); virtual void BuildType(); virtual void BuildP1P1(); virtual void BuildLen(); virtual Product* GetProduct(); private: Product* m_pProduct; }; ////////////////////////////////////////////////////////////////////////// class ConcreteBuilderB : public AbstractBuilder { public: ConcreteBuilderB(Product* pProduct); virtual ~ConcreteBuilderB(); virtual void BuildHead(); virtual void BuildData(); virtual void BuildType(); virtual void BuildP1P1(); virtual void BuildLen(); virtual Product* GetProduct(); private: Product* m_pProduct; }; ////////////////////////////////////////////////////////////////////////// class Director { public: Director(AbstractBuilder* pAbstractBuilder); ~Director(); void Construct1(); void Construct2(); private: AbstractBuilder* m_pAbstractBuilder; }; ////////////////////////////////////////////////////////////////////////// void BuilderPattern_Test_A(); void BuilderPattern_Test_B(); } #endif
实现
#include "BuilderPattern.h" #include <iostream> using namespace std; namespace BuilderPattern { ////////////////////////////////////////////////////////////////////////// Product::Product() { } Product::~Product() { } void Product::AddPart(string strPart) { m_strFullParts += strPart; } string Product::DisplayProduct() { cout << m_strFullParts << endl; return m_strFullParts; } void Product::EmptyParts() { m_strFullParts = ""; } ////////////////////////////////////////////////////////////////////////// AbstractBuilder::AbstractBuilder() { } AbstractBuilder::~AbstractBuilder() { } ////////////////////////////////////////////////////////////////////////// ConcreteBuilderA::ConcreteBuilderA(Product* pProduct) : m_pProduct(NULL) { if (pProduct != NULL) { m_pProduct = pProduct; } } ConcreteBuilderA::~ConcreteBuilderA() { if (m_pProduct != NULL) { delete m_pProduct; m_pProduct = NULL; } } void ConcreteBuilderA::BuildHead() { m_pProduct->AddPart("ConcreteBuilderA::BuildHead\n"); } void ConcreteBuilderA::BuildData() { m_pProduct->AddPart("ConcreteBuilderA::BuildData\n"); } void ConcreteBuilderA::BuildType() { m_pProduct->AddPart("ConcreteBuilderA::BuildType\n"); } void ConcreteBuilderA::BuildP1P1() { m_pProduct->AddPart("ConcreteBuilderA::BuildP1P1\n"); } void ConcreteBuilderA::BuildLen() { m_pProduct->AddPart("ConcreteBuilderA::BuildLen\n"); } Product* ConcreteBuilderA::GetProduct() { return m_pProduct; } ////////////////////////////////////////////////////////////////////////// ConcreteBuilderB::ConcreteBuilderB(Product* pProduct) : m_pProduct(NULL) { if (pProduct != NULL) { m_pProduct = pProduct; } } ConcreteBuilderB::~ConcreteBuilderB() { if (m_pProduct != NULL) { delete m_pProduct; m_pProduct = NULL; } } void ConcreteBuilderB::BuildHead() { m_pProduct->AddPart("ConcreteBuilderB::BuildHea\n"); } void ConcreteBuilderB::BuildData() { m_pProduct->AddPart("ConcreteBuilderB::BuildData\n"); } void ConcreteBuilderB::BuildType() { m_pProduct->AddPart("ConcreteBuilderB::BuildType\n"); } void ConcreteBuilderB::BuildP1P1() { m_pProduct->AddPart("ConcreteBuilderB::BuildP1P1\n"); } void ConcreteBuilderB::BuildLen() { m_pProduct->AddPart("ConcreteBuilderB::BuildLen\n"); } Product* ConcreteBuilderB::GetProduct() { return m_pProduct; } ////////////////////////////////////////////////////////////////////////// Director::Director(AbstractBuilder* pAbstractBuilder) : m_pAbstractBuilder(NULL) { if (pAbstractBuilder != NULL) { m_pAbstractBuilder = pAbstractBuilder; } } Director::~Director() { if (m_pAbstractBuilder != NULL) { delete m_pAbstractBuilder; m_pAbstractBuilder = NULL; } } void Director::Construct1() { m_pAbstractBuilder->GetProduct()->EmptyParts(); m_pAbstractBuilder->BuildData(); m_pAbstractBuilder->BuildType(); m_pAbstractBuilder->BuildP1P1(); m_pAbstractBuilder->BuildLen(); m_pAbstractBuilder->BuildData(); m_pAbstractBuilder->GetProduct()->DisplayProduct(); } void Director::Construct2() { m_pAbstractBuilder->GetProduct()->EmptyParts(); m_pAbstractBuilder->BuildLen(); m_pAbstractBuilder->BuildData(); m_pAbstractBuilder->BuildType(); m_pAbstractBuilder->BuildP1P1(); m_pAbstractBuilder->BuildData(); m_pAbstractBuilder->GetProduct()->DisplayProduct(); } ////////////////////////////////////////////////////////////////////////// void BuilderPattern_Test_A() { Director* pDirector = new Director(new ConcreteBuilderA(new Product())); pDirector->Construct1(); pDirector->Construct2(); delete pDirector; pDirector = NULL; } void BuilderPattern_Test_B() { Director* pDirector = new Director(new ConcreteBuilderB(new Product())); pDirector->Construct1(); pDirector->Construct2(); delete pDirector; pDirector = NULL; } }
客户端
#include "BuilderPattern.h" #include <iostream> using namespace std; using namespace BuilderPattern; void main() { BuilderPattern_Test_A(); BuilderPattern_Test_B(); }
运行结果
- BuilderPattern.zip (1.4 KB)
- 下载次数: 0
- Diagram.zip (501.8 KB)
- 下载次数: 1
- Diagram-raw.zip (54.4 KB)
- 下载次数: 0
发表评论
-
FreeRTOS
2022-03-05 16:31 253Ref https://blog.csdn.net/weix ... -
串口通讯相关
2018-11-02 13:44 417https://bbs.csdn.net/wap/topics ... -
[转]C++验证IP是否可以PING通
2018-10-30 17:54 1346https://www.cnblogs.com/guoyz13 ... -
C++/MFC 換皮膚
2018-10-20 11:05 481https://blog.csdn.net/u01123991 ... -
WinCE 截屏 - C++ 代碼
2018-08-31 09:45 580// this function create a bmp ... -
Android NDK搭建環境
2017-11-27 13:25 593https://www.cnblogs.com/ut2016- ... -
8583协议相关
2017-10-17 13:38 5828583相关资料,整理中... -
Java高级应用之JNI
2017-06-19 09:00 609参考link http://www.cnblogs.com/l ... -
C++实现ping功能
2017-04-18 11:21 2177基础知识 ping的过程是向目的IP发送一个type=8的I ... -
OpenSSL 编译环境搭建
2017-03-27 15:01 9161 安裝VS2008到 c:\Program Files (x ... -
最优非对称加密填充(OAEP)
2017-03-25 14:53 1596OpenSSL命令---rsautl http://blog. ... -
[Platform Builder] 设置SVM OS build Env
2016-11-10 11:39 01 copy one OSDesign Project to ... -
[Windows] System Error Codes(GetLastError )0-----5999
2016-10-26 13:28 1886ERROR_SUCCESS 0 (0x0) T ... -
开源Windows驱动程序框架
2016-09-17 21:35 879转自 http://code.csdn.net/news/28 ... -
c/c++代码中执行cmd命令
2016-09-14 14:50 1928转自 http://blog.csdn.net/slixinx ... -
C#使用C++标准DLL实例(包含callback)
2016-09-11 19:44 1095C++编写标准Win32DLL如下 头文件 /***** ... -
C#调用C++的DLL搜集整理的所有数据类型转换方式
2016-09-09 16:07 974转自 http://www.cnblogs.com/zeroo ... -
WinCE CPU使用率计算 测试工具
2016-09-08 16:14 1006转自 http://blog.csdn.net/jan ... -
switch在C++与C#中的一些差异
2016-09-08 15:19 821参考链接 http://blog.csdn.net/weiwe ... -
C++ 鼠标模拟程序
2016-09-04 12:09 1623转自 http://blog.csdn.net/weixinh ...
相关推荐
**建造者模式(Builder Pattern)**是Java设计模式中的创建型模式之一,它允许我们分步骤构建一个复杂的对象,而不必一次性完成。这种模式的主要目的是将对象的创建过程与使用过程解耦,使得构建过程可以独立地进行...
- 建造者模式(Builder):将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。 - 寄生构造器模式(Prototype):用原型实例指定创建对象的种类,并且通过复制这个原型来创建新的对象。 ...
1. 创建型设计模式:这类模式关注对象的创建过程,它们包括单例模式、工厂方法模式、抽象工厂模式、建造者模式和原型模式。单例模式确保一个类只有一个实例,并提供全局访问点;工厂方法模式定义一个用于创建对象的...
Builder模式是一种创建型设计模式,它提供了一种分步骤创建复杂对象的方法,使得相同构建过程可以创建不同的表示。Builder模式.vsd可能包含了产品类、具体建造者类和导演类的类图,展示了如何逐步构建产品对象。 ...
1. 创建型模式:关注对象的创建,比如工厂模式(用于创建对象而不暴露创建逻辑)、抽象工厂模式(提供一个创建一系列相关或相互依赖对象的接口)、单例模式(确保一个类只有一个实例)、建造者模式(将复杂对象的...
建造者模式将复杂对象的构建与其表示分离,使得同样的构建过程可以创建不同的表示。在C#中,可以通过定义一个建造者接口和多个具体建造者类,来实现不同类型的对象构建。 五、原型模式(Prototype) 原型模式通过...
学习这个模式时,需要注意理解抽象工厂模式与其他创建型模式(如简单工厂、工厂方法和建造者模式)的区别,以及如何在实际项目中合理选择和应用。同时,也要关注模式的优缺点,例如它能很好地封装变化,但可能会导致...