策略模式(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. 可能引入过多的细粒度策略类:如果策略类设计不当,可能会引入过多的细粒度策略类,导致系统过度复杂。

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

相关推荐
南境十里·墨染春水2 小时前
C++传记(面向对象)虚析构函数 纯虚函数 抽象类 final、override关键字
开发语言·c++·笔记·算法
2301_797172752 小时前
基于C++的游戏引擎开发
开发语言·c++·算法
比昨天多敲两行3 小时前
C++ 二叉搜索树
开发语言·c++·算法
Season4503 小时前
C++11之正则表达式使用指南--[正则表达式介绍]|[regex的常用函数等介绍]
c++·算法·正则表达式
问好眼4 小时前
《算法竞赛进阶指南》0x04 二分-1.最佳牛围栏
数据结构·c++·算法·二分·信息学奥赛
海海不瞌睡(捏捏王子)4 小时前
C++ 知识点概要
开发语言·c++
minji...6 小时前
Linux 进程信号(二)信号的保存,sigset_t,sigprocmask,sigpending
linux·运维·服务器·网络·数据结构·c++·算法
小菜鸡桃蛋狗8 小时前
C++——类和对象(下)
开发语言·c++
crescent_悦8 小时前
C++:Highest Price in Supply Chain
开发语言·c++
feng_you_ying_li8 小时前
底层实现map和set的第一步,AVL树的学习
c++