策略模式(C++)三分钟读懂

策略模式(Strategy Pattern)是一种面向对象编程的一种行为型设计模式,它允许在运行时动态地改变算法或策略的选择,从而使算法的变化独立于使用它的客户端。这种模式通过将算法封装在单独的类中,使得它们可以相互替换,并使得它们易于理解、扩展和维护。

多重条件语句不易维护,而使用策略模式可以避免使用多重条件语句,如 if...else 语句、switch...case 语句。

下面用QT框架下C++演示一下

演示代码:

cpp 复制代码
#include <iostream>
#include <QString>
#include <QDebug>

// 策略接口
class SortStrategy {
public:
    virtual void sort(QStringList &list) = 0;
};

// 具体策略A:按照字符串长度排序
class LengthSortStrategy : public SortStrategy {
public:
    void sort(QStringList &list) override {
        list.sort([](const QString &s1, const QString &s2) {
            return s1.length() < s2.length();
        });
    }
};

// 具体策略B:按照字母顺序排序
class AlphabeticalSortStrategy : public SortStrategy {
public:
    void sort(QStringList &list) override {
        list.sort();
    }
};

// 上下文类,用于执行策略
class SortContext {
private:
    SortStrategy *strategy;

public:
    SortContext(SortStrategy *strategy) : strategy(strategy) {}

    void setStrategy(SortStrategy *strategy) {
        this->strategy = strategy;
    }

    void executeStrategy(QStringList &list) {
        strategy->sort(list);
    }
};

int main() {
    QStringList list = {"apple", "banana", "grape", "orange"};

    // 使用策略A:按照字符串长度排序
    SortStrategy *lengthSortStrategy = new LengthSortStrategy();
    SortContext context(lengthSortStrategy);
    context.executeStrategy(list);

    qDebug() << "按照字符串长度排序:";
    for (const QString &item : list) {
        qDebug() << item;
    }

    // 使用策略B:按照字母顺序排序
    SortStrategy *alphaSortStrategy = new AlphabeticalSortStrategy();
    context.setStrategy(alphaSortStrategy);
    context.executeStrategy(list);

    qDebug() << "按照字母顺序排序:";
    for (const QString &item : list) {
        qDebug() << item;
    }

    delete lengthSortStrategy;
    delete alphaSortStrategy;

    return 0;
}

优点:

  1. 灵活性:策略模式可以使算法独立于使用它的客户端而变化,客户端可以在运行时选择合适的算法,动态改变对象的行为,从而提高系统的灵活性。

  2. 可扩展性:通过策略模式,可以很容易地新增新的算法,而无需修改现有代码。这符合开闭原则,使系统更易于扩展。

  3. 代码复用:策略模式可以使相似的算法封装在不同的策略类中,从而提高代码的复用性。

  4. 减少条件分支:策略模式可以减少大量的条件分支语句,使代码更清晰、简洁,易于维护。

  5. 单一职责原则:策略模式使得每个算法都有自己的类,符合单一职责原则,提高了代码的可读性和可维护性。

缺点:

  1. 类数量增多:使用策略模式会增加类的数量,特别是当策略类数量较多时,可能会导致类的膨胀,使得系统变得复杂。

  2. 客户端必须了解所有的策略:客户端需要了解所有的策略类,以便在运行时选择合适的策略,这可能会增加客户端的复杂性。

  3. 可能引入过多的细粒度策略类:如果策略类设计不当,可能会引入过多的细粒度策略类,导致系统过度复杂。

尽管策略模式存在一些缺点,但在很多情况下,其优点远大于缺点,特别是在需要动态改变对象行为、减少条件分支、提高系统灵活性和可扩展性等方面,策略模式仍然是一种非常有价值的设计模式。

相关推荐
一只小小汤圆4 分钟前
编译笔记:vs 中 正在从以下位置***加载符号 C# 中捕获C/C++抛出的异常
c++·c#
小俊俊的博客1 小时前
海康RGBD相机使用C++和Opencv采集图像记录
c++·opencv·海康·rgbd相机
7yewh1 小时前
嵌入式Linux QT+OpenCV基于人脸识别的考勤系统 项目
linux·开发语言·arm开发·驱动开发·qt·opencv·嵌入式linux
_WndProc2 小时前
C++ 日志输出
开发语言·c++·算法
薄荷故人_2 小时前
从零开始的C++之旅——红黑树及其实现
数据结构·c++
m0_748240022 小时前
Chromium 中chrome.webRequest扩展接口定义c++
网络·c++·chrome
qq_433554542 小时前
C++ 面向对象编程:+号运算符重载,左移运算符重载
开发语言·c++
努力学习编程的伍大侠2 小时前
基础排序算法
数据结构·c++·算法
yuyanjingtao2 小时前
CCF-GESP 等级考试 2023年9月认证C++四级真题解析
c++·青少年编程·gesp·csp-j/s·编程等级考试
闻缺陷则喜何志丹3 小时前
【C++动态规划 图论】3243. 新增道路查询后的最短距离 I|1567
c++·算法·动态规划·力扣·图论·最短路·路径