策略工厂模式是将策略模式与工厂模式结合,通过封装算法并按需创建实例的架构设计。其核心优势包括:1.解耦调用方与具体类;2.扩展新策略无需修改代码;3.集中管理创建逻辑。实现结构分为四步:1.定义策略接口;2.实现具体策略类;3.构建工厂类处理创建逻辑;4.注册策略供运行时选择。运行时动态选择策略可通过读取外部输入(如命令行、配置文件)获取标识符,并由工厂返回对应实例,同时需支持灵活输入来源、统一标识格式及错误处理机制。实际开发中建议优化点包括:宏或模板自动注册策略、支持别名、设置默认策略、结合依赖注入框架以及传递初始化参数。

在C++项目中,策略工厂模式结合运行时策略选择,能构建出一个灵活、可扩展的架构。核心在于将策略的创建和使用解耦,并通过配置或输入动态决定使用哪个策略。这种设计不仅提升了代码的可维护性,也方便后期新增策略而无需修改已有逻辑。

策略模式允许你定义一系列算法或行为,并将它们封装成独立类,使得它们可以互换使用。工厂模式则用于集中管理这些策略对象的创建过程。两者结合后,客户端只需提供标识(比如字符串、枚举等),就能获取对应的策略实例。
这种方式的优势在于:
立即学习“C++免费学习笔记(深入)”;

要实现策略工厂,通常需要以下几个部分:
例如,定义一个简单的策略接口:

class Strategy {
public:
virtual void execute() = 0;
virtual ~Strategy() = default;
};然后定义两个具体策略:
class StrategyA : public Strategy {
public:
void execute() override {
std::cout << "Executing Strategy A\n";
}
};
class StrategyB : public Strategy {
public:
void execute() override {
std::cout << "Executing Strategy B\n";
}
};接着是策略工厂:
class StrategyFactory {
public:
using StrategyCreator = std::function<Strategy*()>;
static StrategyFactory& instance() {
static StrategyFactory factory;
return factory;
}
void registerStrategy(const std::string& name, StrategyCreator creator) {
creators_[name] = creator;
}
Strategy* createStrategy(const std::string& name) {
auto it = creators_.find(name);
if (it != creators_.end()) {
return it->second();
}
return nullptr;
}
private:
std::unordered_map<std::string, StrategyCreator> creators_;
};最后,在程序启动时注册策略:
namespace {
Strategy* createStrategyA() { return new StrategyA(); }
Strategy* createStrategyB() { return new StrategyB(); }
struct RegisterStrategies {
RegisterStrategies() {
StrategyFactory::instance().registerStrategy("A", createStrategyA);
StrategyFactory::instance().registerStrategy("B", createStrategyB);
}
} registrar;
}这样就可以在运行时根据传入的字符串选择不同策略了。
为了实现运行时选择策略,关键是让系统能够从外部输入(如命令行参数、配置文件、网络请求等)读取策略标识,并传递给工厂进行创建。
比如,从命令行参数中读取策略名称:
int main(int argc, char* argv[]) {
if (argc < 2) {
std::cerr << "Usage: program <strategy_name>\n";
return 1;
}
std::string strategyName = argv[1];
Strategy* strategy = StrategyFactory::instance().createStrategy(strategyName);
if (!strategy) {
std::cerr << "Unknown strategy: " << strategyName << "\n";
return 1;
}
strategy->execute();
delete strategy;
return 0;
}运行时选择的关键点包括:
如果你希望更健壮一些,还可以引入智能指针来管理内存,或者使用单例策略缓存来提升性能。
在实际项目中,可以考虑以下几点来增强策略工厂的灵活性和可用性:
比如,你可以定义一个宏来简化注册流程:
#define REGISTER_STRATEGY(name, className) \
struct className##Registrar { \
className##Registrar() { \
StrategyFactory::instance().registerStrategy(name, []() -> Strategy* { return new className(); }); \
} \
}; \
static className##Registrar global_##className##_registrar;然后在每个策略类的实现文件中加上:
REGISTER_STRATEGY("A", StrategyA)这样就实现了自动化注册,降低了出错风险。
基本上就这些。只要把策略抽象清楚、工厂实现到位、运行时输入解析好,就能搭建出一个灵活又稳定的策略执行系统。
以上就是C++中策略工厂模式如何结合 运行时策略选择的灵活架构设计的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号