C++ 设计模式:策略模式(Strategy Pattern)

链接:C++ 设计模式
链接:C++ 设计模式 - 模板方法
链接:C++ 设计模式 - 观察者模式

策略模式(Strategy Pattern)是一种行为设计模式,它定义了一系列算法,并将每个算法封装起来,使它们可以相互替换。策略模式使得算法可以独立于使用它的客户端而变化。

1.问题分析

在开发中,经常会遇到需要在运行时选择不同算法或行为的情况。如果将这些算法直接嵌入到客户端代码中,会导致代码复杂且难以维护。策略模式通过将算法封装成独立的类,并通过接口进行调用,使得算法可以灵活地替换和扩展。

2.实现步骤

  1. 定义策略接口:定义一个接口,所有具体策略类都实现这个接口。
  2. 实现具体策略类:每个具体策略类实现策略接口,提供具体的算法实现。
  3. 上下文类:上下文类持有一个策略对象的引用,并通过策略接口调用具体的算法。

3.代码示例

以机器人的清洁任务作为示例。

3.1.策略接口

cpp 复制代码
// 定义机器人任务的公共接口
class CleaningStrategy {
 public:
  virtual ~CleaningStrategy() = default;
  virtual void clean() = 0;
};

3.2.具体策略类

cpp 复制代码
// 策略1,直线清洁
class LinearCleaningStrategy : public CleaningStrategy {
 public:
  void clean() override { std::cout << "Cleaning in a straight line." << std::endl; }
};
cpp 复制代码
// 策略2,螺旋清洁
class SpiralCleaningStrategy : public CleaningStrategy {
 public:
  void clean() override { std::cout << "Cleaning in a spiral pattern." << std::endl; }
};

3.3.上下文类

cpp 复制代码
// 维护一个对策略对象的引用
class CleaningRobot {
 public:
  void setStrategy(std::shared_ptr<CleaningStrategy> strategy) { this->strategy = strategy; }

  void performCleaning() {
    if (strategy) {
      strategy->clean();
    } else {
      std::cout << "No cleaning strategy set." << std::endl;
    }
  }

 private:
  std::shared_ptr<CleaningStrategy> strategy;
};

3.4.调用算法

cpp 复制代码
int main() {
  // 创建一个清洁机器人对象
  CleaningRobot robot;

  // 设置直线清洁策略
  std::shared_ptr<CleaningStrategy> linearStrategy = std::make_shared<LinearCleaningStrategy>();
  robot.setStrategy(linearStrategy);
  robot.performCleaning();

  // 设置螺旋清洁策略
  std::shared_ptr<CleaningStrategy> spiralStrategy = std::make_shared<SpiralCleaningStrategy>();
  robot.setStrategy(spiralStrategy);
  robot.performCleaning();

  return 0;
}
相关推荐
W23035765734 小时前
经典算法:最长上升子序列(LIS)深度解析 C++ 实现
开发语言·c++·算法
.Ashy.4 小时前
2026.4.11 蓝桥杯软件类C/C++ G组山东省赛 小记
c语言·c++·蓝桥杯
minji...5 小时前
Linux 线程同步与互斥(三) 生产者消费者模型,基于阻塞队列的生产者消费者模型的代码实现
linux·运维·服务器·开发语言·网络·c++·算法
CoderCodingNo7 小时前
【GESP】C++三级真题 luogu-B4499, [GESP202603 三级] 二进制回文串
数据结构·c++·算法
hetao17338378 小时前
2026-04-09~12 hetao1733837 的刷题记录
c++·算法
6Hzlia8 小时前
【Hot 100 刷题计划】 LeetCode 136. 只出现一次的数字 | C++ 哈希表&异或基础解法
c++·算法·leetcode
汉克老师9 小时前
GESP2024年6月认证C++三级( 第二部分判断题(1-10))
c++·数组·位运算·补码·gesp三级·gesp3级
无限进步_10 小时前
【C++】只出现一次的数字 II:位运算的三种解法深度解析
数据结构·c++·ide·windows·git·算法·leetcode
小贾要学习10 小时前
【Linux】TCP网络通信编程
linux·服务器·网络·c++·网络协议·tcp/ip