策略模式通过抽象接口定义统一行为契约,由具体策略类实现不同算法,上下文运行时动态切换,实现算法与逻辑解耦。

策略模式在C++中通过接口抽象行为、用具体类实现不同算法,再由上下文动态组合使用——核心是把变化的算法抽成独立类,运行时切换,不改原有逻辑。
用纯虚函数声明统一的行为契约,所有算法都必须遵守这个接口:
class PaymentStrategy {
public:
virtual ~PaymentStrategy() = default;
virtual void pay(double amount) const = 0; // 统一入口,具体实现各不同
};每个类封装一种完整算法,互不影响,新增策略无需动其他代码:
class AlipayStrategy : public PaymentStrategy { void pay(double a) const override { std::cout
class WechatStrategy : public PaymentStrategy { void pay(double a) const override { std::cout
class CreditCardStrategy : public PaymentStrategy { void pay(double a) const override { std::cout
上下文持有策略指针,提供设置和执行接口,完全屏蔽内部策略细节:
立即学习“C++免费学习笔记(深入)”;
class ShoppingCart {
private:
std::unique_ptr<PaymentStrategy> strategy_;
public:
void setStrategy(std::unique_ptr<PaymentStrategy> s) {
strategy_ = std::move(s);
}
void checkout(double total) const {
if (strategy_) strategy_->pay(total);
else throw std::runtime_error("No payment strategy set");
}
};使用时自由替换:
cart.setStrategy(std::make_unique<alipaystrategy>());</alipaystrategy>cart.setStrategy(std::make_unique<wechatstrategy>());</wechatstrategy>策略对象通常由上下文管理,推荐用std::unique_ptr明确归属;若需共享,可用std::shared_ptr但注意循环引用;不要传裸指针或栈对象地址,容易悬空。
策略本身应保持无状态或仅依赖构造参数——这样才真正可复用、可测试、可并发。
以上就是c++++的策略模式如何实现 轻松替换算法和行为【设计模式】的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号