QtC++ 设计模式(四)——策略模式

策略模式

序言

还是参考的菜鸟教程,会C++的还是看C++的方式来得舒服。

.

理解

使用符合UML规范的便于理解和回忆,接口其实就是普通的基类

.

源码

strategy.h

cpp 复制代码
/// 策略
class Strategy
{
public:
    virtual ~Strategy();
    
    /**
     * @brief 计算
     * @param num1 计算数值
     * @param num2 被计算数值
     * @return 
     */
    virtual int operation(const int& num1, const int& num2) = 0;
};

/// 加策略
class AddOperation : public Strategy
{
public:
	/**
     * @brief 加计算
     * @param num1 计算数值
     * @param num2 被计算数值
     * @return 
     */
    int operation(const int &num1, const int &num2) override;
};

/// 减策略
class SubtractOperation : public Strategy
{
public:
	/**
     * @brief 减计算
     * @param num1 计算数值
     * @param num2 被计算数值
     * @return 
     */
    int operation(const int &num1, const int &num2) override;
};

/// 上下文
class Context
{
public:
    /**
     * @brief 构造一个策略的上下文
     * @param strategy 策略对象
     */
    explicit Context(Strategy *strategy);
    ~Context();

	/**
     * @brief 计算
     * @param num1 计算数值
     * @param num2 被计算数值
     * @return 
     */
    int operation(const int &num1, const int &num2);

private:
	/// 所拥有的策略
    Strategy *strategy = nullptr;
};

.

strategy.cpp

cpp 复制代码
Strategy::~Strategy()
{

}

int AddOperation::operation(const int &num1, const int &num2)
{
    return num1 + num2;
}

int SubtractOperation::operation(const int &num1, const int &num2)
{
    return num1 - num2;
}

Context::Context(Strategy *strategy)
    : strategy(strategy)
{

}

Context::~Context()
{
    if (strategy)
        delete strategy;
}

int Context::operation(const int &num1, const int &num2)
{
    if (strategy)
    {
        return strategy->operation(num1, num2);
    }
    return INT_MIN;
}

.

使用的地方

cpp 复制代码
std::shared_ptr< Context > context(new Context(new AddOperation));
std::cout << context->operation(10, 5) << std::endl;

context.reset(new Context(new SubtractOperation));
std::cout << context->operation(10, 5) << std::endl;

不同策略则生成不同的对象给Context,Context会根据其拥有的策略进行运算。

相关推荐
Dream it possible!6 小时前
LeetCode 热题 100_字符串解码(71_394_中等_C++)(栈)
c++·算法·leetcode
My Li.7 小时前
c++的介绍
开发语言·c++
邪恶的贝利亚8 小时前
C++之序列容器(vector,list,dueqe)
开发语言·c++
原来是猿8 小时前
蓝桥备赛(13)- 链表和 list(上)
开发语言·数据结构·c++·算法·链表·list
成功助力英语中国话9 小时前
SDK编程,MFC编程,WTL编程之间的关系
c++·mfc
仟濹9 小时前
【算法 C/C++】二维差分
c语言·c++·算法
总斯霖10 小时前
题解:士兵排列
数据结构·c++·算法
稳兽龙10 小时前
P4268 [USACO18FEB] Directory Traversal G
c++·算法·换根dp
放氮气的蜗牛10 小时前
C++从入门到精通系列教程之第十篇:异常处理与调试技巧
开发语言·jvm·c++
LL59621456910 小时前
CEF在MFC上的示例工程
c++·mfc·cef