boost::factory实现对象工厂设计模式
来源:互联网 发布:linglong 女性版 知乎 编辑:程序博客网 时间:2024/04/19 07:27
转载自:http://blog.csdn.net/mpforwd/article/details/5791699
#ifndef MP_OBJECT_FACTORY_H #define MP_OBJECT_FACTORY_H #include <boost/function.hpp> #include <map> /// 工厂模式泛型实现. /// 限制: 生成的对象必须为通过默认构造函数来构造. /// 当然你也可以扩展这个模板让它支持更多参数的构造函数. template<typename IdType, typename ObjectType> class ObjectFactory { public: /// 表示默认构造函数的函数对象. typedef boost::function< ObjectType* () > CreatorType; /// 构造函数对应的函数对象的关联容器. typedef std::map<IdType, CreatorType> ObjectCreator_map; /// 注册子类对象的构造函数信息. void RegisterObjectCreator(const IdType& id, const CreatorType &creator) { objectCreatorMap_[id] = creator; } /// 通过默认构造函数在堆上创建一个新的对象实例. 使用new生成. ObjectType * MakeObject(const IdType& id) { ObjectCreator_map::const_iterator iter = objectCreatorMap_.find(id); if (iter == objectCreatorMap_.end()) { return NULL; } else { return (iter->second)(); } } private: ObjectCreator_map objectCreatorMap_; }; #endif
#include "Product.h" #include "ConcreteProductA.h" #include "ConcreteProductB.h" #include "ObjectFactory.h" #include <string> #include <boost/functional/factory.hpp> int main(int argc, char **argv) { ObjectFactory<std::string, Product> productFactory; // 对象工厂 // 注册对象构造器. productFactory.RegisterObjectCreator("PRODUCT_A", boost::factory<ConcreteProductA *>() ); productFactory.RegisterObjectCreator("PRODUCT_B", boost::factory<ConcreteProductB *>() ); //通过工厂生成对象, 存储在shared_ptr中. Product_ptr productA( productFactory.MakeObject("PRODUCT_A") ); Product_ptr productB( productFactory.MakeObject("PRODUCT_B") ); // 演示多态性质。 productA->DoSomething(); productB->DoSomething(); return 0; }
在以上测试中,我们首先生成一个对象工厂,这里我们以std::string作为IdType来标示是哪种类型的ConcreteProduct。
然后向工厂中注册具体类的构造方法: productFactory.RegisterObjectCreator("PRODUCT_A", boost::factory<ConcreteProductA *>() ); 注意:这里用到了boost::factory,它可以将 new 表达式封装成函数对象(function object), 这也正式我们工厂的注册方法所需要的参数。
后面我们调用对象工厂的MakeObject来生成我们期望的ConcreteProduct对象。 我们用一个字符串来标识要生成哪种类型的ConcreteProduct对象。同时我们将返回的对象指针保存在 shared_ptr中,从而实现对象的自动管理。 类型Product_ptr的定义为: typedef boost::shared_ptr<Product> Product_ptr; 它是对Product接口的智能指针封装。
最后,就是展示多态行为的时候了,我们调用不同ConcreteProduct对象的DoSomething来演示。
限制说明:
1. 本文只是实现了带有默认构造函数的对象工厂。 如果你愿意也可以实现带有多个参数构造函数的对象工厂。
2. ObjectFactory 也可以实现为Singleton模式,根据个人需要吧,本文的重点不在这里。
- boost::factory实现对象工厂设计模式
- 以boost factory & boost function实现对象工厂设计模式
- C++实现设计模式: Factory 工厂模式
- C++实现设计模式: Factory 工厂模式
- C++实现设计模式: Factory 工厂模式
- 工厂设计模式 factory
- [设计模式]Factory工厂模式
- 设计模式--工厂模式Factory
- 设计模式 -- 工厂模式(Factory)
- 设计模式--工厂模式Factory
- 设计模式 - Factory工厂模式
- 大话设计模式--工厂模式 factory -- C++实现实例
- 大话设计模式--工厂方法模式 Factory Method -- C++实现
- 设计模式之工厂模式(Factory Pattern)用C++实现
- 设计模式 - 抽象工厂模式(Abstract Factory) C++实现
- C++设计模式 factory工厂模式,实现绘制几何形状
- Python实现设计模式--02.工厂模式(Factory Pattern)
- 设计模式-资源工厂(Resource Factory) - 对象创建型
- 百度地图在合适的视野显示所有标注
- 设计模式的应用场景(23)--解释器模式
- 约瑟夫环问题
- Tensorflow的一些基本用法
- Android framework 使用自定的activity取代默认的Launcher界面
- boost::factory实现对象工厂设计模式
- 大数据之R语言速成与实战,免费送给数据分析爱好者
- JavaScript基础学习之旅
- java 实现发送短信
- intelij idea 设置方法和类注释快捷键
- 25读书笔记之播放多媒体文件
- 数据库操作大全(不断记录积累)!!
- Azure快速部署web应用之mysql数据库连接篇
- 微服务阅读书籍地址