C++策略模式

  1. 1 简介: 策略模式是一种行为型设计模式,用于在运行时根据不同的情况选择不同的算法或行为。它将算法封装成一个个具体的策略类,并使这些策略类可以相互替换,以达到动态改变对象的行为的目的。

  2. 2 实现步骤: 以下是使用C++实现策略模式的步骤:

    a. 定义策略接口:首先,定义一个策略接口,该接口声明了策略类中的算法方法。

    cpp 复制代码
    class Strategy {
    public:
        virtual void doAlgorithm() = 0;
    };

    b. 实现具体策略类:创建实现策略接口的具体策略类,每个具体策略类都实现了算法方法。

    cpp 复制代码
    class ConcreteStrategyA : public Strategy {
    public:
        void doAlgorithm() override {
            // 具体策略A的算法实现
        }
    };
    
    class ConcreteStrategyB : public Strategy {
    public:
        void doAlgorithm() override {
            // 具体策略B的算法实现
        }
    };

    c. 创建环境类:创建一个环境类,用于保存当前使用的策略对象,并且提供一个方法来改变策略对象。

    cpp 复制代码
    class Context {
    private:
        Strategy* strategy;
    
    public:
        void setStrategy(Strategy* newStrategy) {
            strategy = newStrategy;
        }
    
        void executeAlgorithm() {
            strategy->doAlgorithm();
        }
    };

    3 示例代码: 以下是一个使用策略模式的示例代码:

    cpp 复制代码
    #include <iostream>
    
    int main() {
        // 创建环境对象
        Context context;
    
        // 创建具体策略A
        Strategy* strategyA = new ConcreteStrategyA();
    
        // 设置具体策略A
        context.setStrategy(strategyA);
    
        // 执行算法
        context.executeAlgorithm();
    
        delete strategyA;
    
        // 创建具体策略B
        Strategy* strategyB = new ConcreteStrategyB();
    
        // 设置具体策略B
        context.setStrategy(strategyB);
    
        // 执行算法
        context.executeAlgorithm();
    
        delete strategyB;
    
        return 0;
    }
  3. 上述代码中,客户端可以根据需求选择不同的具体策略来执行算法,通过改变策略对象,动态地改变行为。

  4. 4 优点:

    • 算法的实现与客户端解耦,增加代码的灵活性和可维护性。
    • 可以方便地扩展和添加新的策略类,符合开闭原则。
  5. 5 注意事项:

    • 在使用策略模式时,需要确定出多个具体策略类之间的差异性和相似性,以及它们共同实现的策略接口。
相关推荐
忘梓.1 分钟前
二叉搜索树·极速分拣篇」:用C++怒肝《双截棍》分拣算法,暴打节点删除Boss战!
开发语言·c++·算法
星辰徐哥2 分钟前
Java数组的定义、操作与应用场景
java·开发语言
Aileen_0v03 分钟前
【数据结构中链表常用的方法实现过程】
java·开发语言·数据结构·算法·链表·动态规划·csdn开发云
闻缺陷则喜何志丹5 分钟前
【C++DFS 马拉车】3327. 判断 DFS 字符串是否是回文串|2454
c++·算法·深度优先·字符串·力扣·回文·马拉车
晨非辰6 分钟前
【数据结构入坑指南(三.1)】--《面试必看:单链表与顺序表之争,读懂“不连续”之美背后的算法思想》
数据结构·c++·人工智能·深度学习·算法·机器学习·面试
旖旎夜光6 分钟前
哈希(14)(下)
数据结构·c++·学习
拾光Ծ8 分钟前
哈希表进阶:挑战用哈希桶封装unordered_set和unordered_map,帮你深度理解迭代器!!!
数据结构·c++·哈希算法·散列表
给我一瓶哇哈哈呀9 分钟前
[ROS2] CMU团队的Autonomous Exploration算法+MID-360部署到实车记录
c++·自动驾驶
草莓熊Lotso9 分钟前
《算法闯关指南:优选算法--滑动窗口》--15.串联所有单词的子串,16.最小覆盖子串
开发语言·c++·人工智能·算法
Andy Dennis25 分钟前
一文认识Java常见集合
java·开发语言