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

策略模式详解与应用

策略模式(Strategy Pattern),是一种行为型设计模式,它定义了一系列算法,并将每个算法封装起来,使它们可以互相替换,而应用程序可以在运行时选择使用哪一个算法。策略模式使得算法的变化独立于使用该算法的客户。通过将不同的算法封装为独立的类,策略模式能够提供更高的灵活性和可扩展性,同时也简化了客户端代码。

策略模式的特点

  1. 易于扩展:新增加一个策略只需要添加一个新的具体策略类,而不需要修改现有的代码。
  2. 避免条件语句:减少了大量的if-elseswitch-case等条件判断逻辑。
  3. 符合开闭原则:对扩展开放,对修改关闭。
  4. 促进代码重用:多个上下文环境可以共享同一个策略实现。
  5. 分离关注点:将算法的具体实现从调用者中分离出来,降低了耦合度。
  6. 支持多种算法组合:可以轻松地组合不同策略来达到复杂的行为。

策略模式的组成

  • Context(上下文环境):这是客户使用的接口,负责维持对当前策略对象的引用,并根据需要切换到其他策略。
  • Strategy(抽象策略接口/抽象类):定义了一个接口,用于封装一系列相关算法。所有具体策略类都必须实现这个接口。
  • ConcreteStrategy(具体策略类):实现了Strategy接口,并包含了特定算法的实现细节。

策略模式的实现

我们将通过一个简单的例子来演示策略模式的应用:假设我们正在开发一个电商系统,其中有一个折扣计算模块,用来根据不同类型的促销活动(如节日特惠、会员日优惠、满减等)来计算商品的价格折扣。我们可以使用策略模式来管理这些不同的折扣计算方式,确保每次促销活动都能正确地应用相应的折扣规则。

示例代码

// 抽象策略 - DiscountStrategy
interface DiscountStrategy {double calculateDiscount(double originalPrice);
}// 具体策略 - HolidayDiscount
class HolidayDiscount implements DiscountStrategy {@Overridepublic double calculateDiscount(double originalPrice) {return originalPrice * 0.9; // 假设节日特惠是打九折}
}// 具体策略 - MemberDayDiscount
class MemberDayDiscount implements DiscountStrategy {@Overridepublic double calculateDiscount(double originalPrice) {return originalPrice * 0.85; // 假设会员日优惠是打八五折}
}// 具体策略 - FullReductionDiscount
class FullReductionDiscount implements DiscountStrategy {private final double threshold;private final double reduction;public FullReductionDiscount(double threshold, double reduction) {this.threshold = threshold;this.reduction = reduction;}@Overridepublic double calculateDiscount(double originalPrice) {if (originalPrice >= threshold) {return originalPrice - reduction;} else {return originalPrice;}}
}// 上下文环境 - ShoppingCart
class ShoppingCart {private DiscountStrategy discountStrategy;public void setDiscountStrategy(DiscountStrategy strategy) {this.discountStrategy = strategy;}public double getTotalPrice(double originalPrice) {if (discountStrategy != null) {return discountStrategy.calculateDiscount(originalPrice);}return originalPrice;}
}

使用示例

public class StrategyPatternDemo {public static void main(String[] args) {ShoppingCart cart = new ShoppingCart();// 模拟用户选择不同的折扣策略System.out.println("Original price: $100");cart.setDiscountStrategy(new HolidayDiscount());System.out.printf("Holiday discount price: $%.2f\n", cart.getTotalPrice(100));cart.setDiscountStrategy(new MemberDayDiscount());System.out.printf("Member day discount price: $%.2f\n", cart.getTotalPrice(100));cart.setDiscountStrategy(new FullReductionDiscount(100, 20));System.out.printf("Full reduction discount price: $%.2f\n", cart.getTotalPrice(100));}
}

策略模式的应用场景

  • 当你有一组相关的算法或行为,并且希望在运行时灵活地选择其中一种执行时。
  • 在构建游戏中的AI决策树时,可以根据不同的情况采用不同的行动策略。
  • 对于支付网关的选择,可以根据用户的偏好或地区动态更改支付处理器。
  • 实现排序功能时,允许用户指定不同的排序规则(升序、降序、按字母顺序等)。
  • 构建文本编辑器中的格式化工具栏,让用户可以选择不同的文本样式(粗体、斜体、下划线等)。
  • 在图形处理软件中,提供多种滤镜效果供用户选择。

结语

希望本文能帮助您更好地理解策略模式的概念及其实际应用。如果您有任何疑问或建议,请随时留言交流。


http://www.mrgr.cn/news/83481.html

相关文章:

  • 计算机网络(第8版)第四章 网络层(4.10.1~4.10.3)
  • pytest 参数介绍
  • 第34天:安全开发-JavaEE应用反射机制攻击链类对象成员变量方法构造方法
  • 计算机图形学【绘制立方体和正六边形】
  • uni-app无限级树形组件简单实现
  • git: hint:use --reapply-cherry-picks to include skipped commits
  • [创业之路-243]:《华为双向指挥系统》-1-组织再造-企业不同组织形式下的指挥线的种类?
  • AI刷题-数列推进计算任务、数组中的幸运数问题
  • 【DAPM杂谈之三】DAPM的初始化流程
  • 单片机Day1
  • 代码随想录 字符串 test1
  • MathBuddyGUI:带控制系统仿真功能、积分运算的计算器,MATLAB课程设计
  • Vue3学习总结
  • Liunx-搭建安装VSOMEIP环境教程 执行 运行VSOMEIP示例demo
  • 李宏毅机器学习课程笔记02 | 机器学习任务攻略General Guide
  • week06_预训练语言模型—BERT
  • Android车机DIY开发之软件篇(八)单独编译
  • 全面教程:Nacos 2.3.2 启用鉴权与 MySQL 数据存储配置
  • Tkinter组件-Button按键
  • 《ROS2 机器人开发 从入门道实践》 鱼香ROS2——第6章内容
  • Windows 下Mamba2 / Vim / Vmamba 环境安装问题记录及解决方法终极版(无需绕过triton)
  • 攻防靶场(34):隐蔽的计划任务提权 Funbox1
  • 【云计算】OpenStack云计算平台
  • Qt 5.14.2 学习记录 —— 십일 QLCDNumber、ProgressBar、QCalendarWidget
  • 前端开发:Web前端和HTML
  • C++之函数提高