首页 > 后端开发 > C++ > 正文

C++怎么实现一个策略模式_C++设计模式与策略模式实现

下次还敢
发布: 2025-11-10 18:16:03
原创
407人浏览过
策略模式通过封装不同算法并使其可互换,提升代码灵活性;示例中Sorter上下文调用不同排序策略,体现多态与开闭原则。

c++怎么实现一个策略模式_c++设计模式与策略模式实现

策略模式是一种行为型设计模式,它让你定义一系列算法或行为,并将每种行为封装在独立的类中,使它们可以互换使用。在C++中实现策略模式,关键在于通过基类指针调用派生类的虚函数,从而实现运行时多态。

策略模式的核心结构

策略模式包含三个主要角色:

  • Strategy(策略接口): 定义所有支持算法的公共接口,通常是一个抽象基类,含有一个纯虚函数。
  • ConcreteStrategy(具体策略): 实现Strategy接口的具体类,每个类代表一种算法。
  • Context(上下文): 持有一个Strategy对象的引用或指针,客户端通过Context来使用具体的策略。

一个简单的C++实现示例

假设我们要实现不同的排序策略(如冒泡排序、快速排序),可以这样设计:

// 策略接口 class SortStrategy { public: virtual ~SortStrategy() = default; virtual void sort(std::vector& data) const = 0; };

// 具体策略:冒泡排序 class BubbleSort : public SortStrategy { public: void sort(std::vector& data) const override { for (size_t i = 0; i < data.size(); ++i) for (size_t j = 0; j < data.size() - i - 1; ++j) if (data[j] > data[j+1]) std::swap(data[j], data[j+1]); } };

// 具体策略:快速排序 class QuickSort : public SortStrategy { public: void sort(std::vector& data) const override { quickSortImpl(data, 0, data.size() - 1); }

private: void quickSortImpl(std::vector& arr, int low, int high) const { if (low < high) { int pi = partition(arr, low, high); quickSortImpl(arr, low, pi - 1); quickSortImpl(arr, pi + 1, high); } }

int partition(std::vector<int>& arr, int low, int high) const {
    int pivot = arr[high];
    int i = low - 1;
    for (int j = low; j < high; ++j) {
        if (arr[j] <= pivot) {
            ++i;
            std::swap(arr[i], arr[j]);
        }
    }
    std::swap(arr[i + 1], arr[high]);
    return i + 1;
}
登录后复制

};

立即学习C++免费学习笔记(深入)”;

// 上下文类 class Sorter { private: const SortStrategy* strategy;

public: explicit Sorter(const SortStrategy* strat = nullptr) : strategy(strat) {}

void setStrategy(const SortStrategy* strat) {
    strategy = strat;
}

void performSort(std::vector<int>& data) const {
    if (strategy)
        strategy->sort(data);
}
登录后复制

};

如何使用这个策略模式

客户端代码可以根据需要动态切换排序算法

AIBox 一站式AI创作平台
AIBox 一站式AI创作平台

AIBox365一站式AI创作平台,支持ChatGPT、GPT4、Claue3、Gemini、Midjourney等国内外大模型

AIBox 一站式AI创作平台 31
查看详情 AIBox 一站式AI创作平台
int main() { std::vector data = {64, 34, 25, 12, 22, 11, 90};
Sorter sorter;

// 使用冒泡排序
BubbleSort bubble;
sorter.setStrategy(&bubble);
sorter.performSort(data);
// 此时 data 已排序

// 切换为快速排序
QuickSort quick;
sorter.setStrategy(&quick);
sorter.performSort(data);

return 0;
登录后复制

}

这种设计让算法的变化独立于使用它的客户端,符合开闭原则——对扩展开放,对修改关闭。

优点与适用场景

策略模式的优势包括:

  • 避免使用大量的条件语句(如if-else或switch)选择算法。
  • 算法可以独立于使用它的类进行变化和扩展。
  • 便于单元测试,每个策略可以单独测试。

常见应用场景有:不同支付方式、多种数据压缩算法、渲染策略、路径规划等。

基本上就这些。只要理解了多态和接口抽象,C++中的策略模式实现并不复杂,但能显著提升代码的灵活性和可维护性。

以上就是C++怎么实现一个策略模式_C++设计模式与策略模式实现的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号