C++中实现自动注册的工厂

很长时间没有更新博客了,不是博主懒,是因为博主在帮研究生妹子弄硕士论文,定位方面的,被imu,行人航迹,激光匹配各种虐,不说了,都是泪。

Factory模式,在工程中多用了创建派生类实例,内部一般使用switch-case根据不同的key去创建不同的派生类对象。

switch(Key) {
    case A: 
        return new A;
    case B:
        return new B;

    ...
}

对于继承体系简单的,这种还可以,如果对于一个复杂的体系,比如一个命令系统,最后其有100多个业务命令的类,那难道你还想把switch-case写成和懒婆娘的裹脚布一样,又臭又长,显然是不可以的,今天我们就来实现一个自动注册的工厂。
其实这个设计思路我在很早之前就看过,第一次好像是在cpp博客,第二次是在csdn,最近cpp社区“行知一”又看见了,但是他们那个只是一个demo代码,虽然这里我们只是简单的写写,但是尽量让其可以直接使用。
其实思路很简单,借助于map数据结构,标示类唯一的身份标记作为map的key,而value则是一个lambda表达式,其用来产生类实例。
factory的代码如下:

#ifndef FACTORY
#define FACTORY


#include <string>
#include <map>
#include <functional>

using namespace std;

template <typename T, typename K = std::string>
cla
  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
C++可以通过使用抽象类和虚函数来实现工厂模式。抽象工厂模式是一种创建型设计模式,它提供了一种封装一组相关对象创建的方式,而无需指定具体的类。 在C++,可以通过以下步骤来实现抽象工厂模式: 1. 定义抽象基类(Abstract Base Class):创建一个抽象基类,该类定义了一组纯虚函数,用于创建不同类型的产品对象。 ```cpp class AbstractProduct { public: virtual void operation() = 0; }; ``` 2. 定义具体产品类(Concrete Product Classes):创建一组具体产品类,这些类继承自抽象基类,并实现其纯虚函数。 ```cpp class ConcreteProductA : public AbstractProduct { public: void operation() override { // 具体产品A的操作 } }; class ConcreteProductB : public AbstractProduct { public: void operation() override { // 具体产品B的操作 } }; ``` 3. 定义抽象工厂类(Abstract Factory Class):创建一个抽象工厂类,该类定义了一组纯虚函数,用于创建不同类型的产品对象。 ```cpp class AbstractFactory { public: virtual AbstractProduct* createProduct() = 0; }; ``` 4. 定义具体工厂类(Concrete Factory Classes):创建一组具体工厂类,这些类继承自抽象工厂类,并实现其纯虚函数。 ```cpp class ConcreteFactoryA : public AbstractFactory { public: AbstractProduct* createProduct() override { return new ConcreteProductA(); } }; class ConcreteFactoryB : public AbstractFactory { public: AbstractProduct* createProduct() override { return new ConcreteProductB(); } }; ``` 通过以上步骤,我们就可以使用抽象工厂模式来创建不同类型的产品对象。具体使用时,可以根据需要选择具体的工厂类来创建产品对象。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值