贝利信息

c++怎么实现策略模式_c++ 接口抽象与具体算法封装【案例】

日期:2026-01-21 00:00 / 作者:冰火之心
策略接口须用class声明纯虚函数:virtual void execute() = 0且virtual ~Strategy() = default;策略类应无状态、构造轻量、依赖注入;上下文用std::unique_ptr持有;编译期优选模板,运行时用虚函数,variant适用于少量固定策略。

策略接口怎么用 class 声明才真正抽象

纯虚函数是唯一能保证「调用方不依赖具体实现」的手段。只声明 virtual void execute() 不够,必须加 = 0 并把析构函数也设为虚函数,否则多态删除会出未定义行为。

具体策略类如何避免重复构造开销

每个策略类本质是无状态的——它只封装行为,不保存上下文。所以不该在构造函数里做耗时操作,更不该缓存外部对象指针。

上下文类怎么安全持有策略指针

std::unique_ptr 最稳妥。裸指针易悬空,shared_ptr 会引入不必要的引用计数开销,且策略之间本就不该共享生命周期。

编译期策略选择比运行时更高效?什么时候该用 std::variant

当策略数量固定、编译期可知,且对性能极度敏感(比如高频循环内调用),模板参数化策略比虚函数调用快一个数量级。但代价是二进制体积增大、调试困难。

策略模式最难的不是写对虚函数,而是判断哪个类该负责创建策略、谁来决定切换时机、以及是否允许策略间共享状态——这些边界一旦模糊,就变成更难维护的状态模式。