当前位置: 首页 > article >正文

设计模式之策略设计模式

一、状态设计模式概念

策略模式(Strategy) 是一种行为设计模式, 它能让你定义一系列算法, 并将每种算法分别放入独立的类中, 以使算法的对象能够相互替换。

 适用场景

  • 当你想使用对象中各种不同的算法变体, 并希望能在运行时切换算法时, 可使用策略模式。
  • 当你有许多仅在执行某些行为时略有不同的相似类时, 可使用策略模式。
  • 如果算法在上下文的逻辑中不是特别重要, 使用该模式能将类的业务逻辑与其算法实现细节隔离开来。
  • 当类中使用了复杂条件运算符以在同一算法的不同变体中切换时, 可使用该模式。

状态设计模式的结构

  1. 上下文 (Context) 维护指向具体策略的引用, 且仅通过策略接口与该对象进行交流。
  2. 策略 (Strategy) 接口是所有具体策略的通用接口, 它声明了一个上下文用于执行策略的方法。
  3. 具体策略 (Concrete Strategies) 实现了上下文所用算法的各种不同变体。
  4. 当上下文需要运行算法时, 它会在其已连接的策略对象上调用执行方法。 上下文不清楚其所涉及的策略类型与算法的执行方式。
  5. 客户端 (Client) 会创建一个特定策略对象并将其传递给上下文。 上下文则会提供一个设置器以便客户端在运行时替换相关联的策略。

代码如下:

            问题:做一款打斗游戏,玩家使用的英雄使用不同的武器将会产生不同的损伤效果。
            解决方案:定义一些列的算法,把他们一个个封装起来,并且使它们可以相互替换。本模式使得算法可以独立于使用它的客户而变化。

#include <iostream>
#include <string>
class Weapon
{
public:
	virtual std::string fightAlgorithm() const = 0;
};

class Nife: public Weapon
{
public:
	std::string fightAlgorithm() const override
	{
        return "nife";
	}
};

class Axe : public Weapon
{
public:
	std::string fightAlgorithm() const override
	{
		return "Axe";
	}
};

//context
class Hero
{
private:
	Weapon* m_weapon;
public:
	Hero(Weapon* weapon=nullptr) : m_weapon(weapon)
	{

	}
	void setWeapon(Weapon* weapon)
	{
		m_weapon = weapon;
	}
	void fight()
	{
		std::cout << m_weapon->fightAlgorithm() << std::endl;
	}
};

int main()
{
	std::cout<<"客户端:nife攻击"<<std::endl;
    Nife nife;
    Hero hero1(&nife);
    hero1.fight();

    std::cout<<"客户端:Axe攻击"<<std::endl;
    Axe axe;
    hero1.setWeapon(&axe);
    hero1.fight();
    return 0;
}

 二、与其他模式的关系

  • 桥接模式 (opens new window)、 状态模式 (opens new window)和策略模式 (opens new window)(在某种程度上包括适配器模式 (opens new window)) 模式的接口非常相似。 实际上, 它们都基于组合模式 (opens new window)——即将工作委派给其他对象, 不过也各自解决了不同的问题。 模式并不只是以特定方式组织代码的配方, 你还可以使用它们来和其他开发者讨论模式所解决的问题。
  • 状态 (opens new window)可被视为策略 (opens new window)的扩展。 两者都基于组合机制: 它们都通过将部分工作委派给 “帮手” 对象来改变其在不同情景下的行为。 策略使得这些对象相互之间完全独立, 它们不知道其他对象的存在。 但状态模式没有限制具体状态之间的依赖, 且允许它们自行改变在不同情景下的状态。

http://www.kler.cn/a/323958.html

相关文章:

  • Java中的集合类与线程安全的讨论
  • 活动|华院计算作为联盟理事单位出席进博会全球人工智能合作论坛
  • HarmonyOS ArkTs 解决流式传输编码问题
  • String类型
  • 如何在 Ubuntu 上 部署 OceanBase
  • 从python源码到可自动更新软件
  • vue仿chatGpt的AI聊天功能--大模型通义千问(阿里云)
  • 鼎跃安全丨多功能气体检测报警系统:工业安全守护者
  • 菱形继承的类对父类的初始化、组合、多态、多态的原理等的介绍
  • C#基础:掌握控制流语句,构建灵活的程序逻辑
  • Python中的“属性与方法”:解锁面向对象编程的秘密
  • 2024年9月25日,Intel发布至强6900P系列:128核心504MB缓存,终于追上AMD!
  • 跨多场景帧重建DENSER:使用小波估计进行城市动态场景重构
  • 机器学习:探索未知边界,解锁智能潜力
  • 华为-单臂路由
  • 服务运营 | 运营前沿:生成式AI改变医疗保健的运作方式
  • SignApp签名工具/美淘iOS在线签名工具/后端PHP
  • MATLAB与Docker Compose:实现微服务API文档的自动化部署与Vue.js集成
  • 算法分类自动驾驶主要算法介绍
  • 三分钟让你掌握PDF转音频:PDF2Audio背后的秘密
  • 2016年国赛高教杯数学建模C题电池剩余放电时间预测解题全过程文档及程序
  • easyexcel常见问题分析
  • html怎么让字体变颜色
  • Android (rust) vulkan (JNI) 画一个三角形: VulkanSurfaceView 初始化
  • ceph rgw 桶分片之reshard
  • 华为GaussDB数据库之Yukon安装与使用