如何运用策略模式与工厂模式优化复杂的条件判断逻辑?

策略模式封装不同行为算法,工厂模式根据类型创建对应策略实例,二者结合将条件判断收拢至工厂,主流程仅执行策略,提升可扩展性与可维护性。

如何运用策略模式与工厂模式优化复杂的条件判断逻辑?

当代码中出现大量 if-else 或 switch-case 判断,尤其是根据类型、状态或行为分支执行不同逻辑时,维护和扩展都会变得困难。策略模式与工厂模式结合使用,能有效解耦条件判断与具体行为,提升代码的可读性与可扩展性。

策略模式:封装变化的行为

策略模式将每一种算法或行为封装成独立的类,使它们可以互相替换。通过统一接口调用不同实现,避免在主流程中写死逻辑。

例如,一个订单折扣计算功能,根据用户类型(普通、VIP、SVIP)采用不同计算方式:

  • 定义策略接口:DiscountStrategy,包含 calculate(amount)
  • 实现具体策略类:NormalDiscount、VIPDiscount、SVIPDiscount
  • 上下文类 OrderProcessor 接收策略实例并执行计算

这样,新增折扣类型无需修改原有判断逻辑,只需添加新策略类并接入即可。

工厂模式:解耦对象创建

虽然策略模式分离了行为,但选择哪个策略仍可能依赖条件判断。工厂模式负责根据输入(如用户类型)创建对应的策略实例,把“选哪个”从主流程中剥离。

如何运用策略模式与工厂模式优化复杂的条件判断逻辑?

Smodin AI Content Detector

多语种ai内容检测工具

如何运用策略模式与工厂模式优化复杂的条件判断逻辑?51

查看详情 如何运用策略模式与工厂模式优化复杂的条件判断逻辑?

  • 创建 DiscountStrategyFactory
  • 工厂内部包含映射关系,如 { “normal”: NormalDiscount, “vip”: VIPDiscount }
  • 对外提供 getStrategy(userType) 方法,返回对应策略实例

调用方只需传入类型,拿到策略对象,无需知道创建细节,也不接触 if-else 分支。

组合使用:清晰分工,易于维护

实际调用流程如下:

  • 接收用户类型 userType
  • 调用 factory.getStrategy(userType) 获取策略对象
  • orderProcessor.setStrategy(strategy)
  • processor.calculate(totalAmount)

if-else 判断被收拢到工厂内部,甚至可以用配置或映射表替代,后期扩展只需注册新策略,不改动核心逻辑。

优势与适用场景

这种组合特别适合:

  • 多分支业务规则,如支付方式、审批流程、消息通知渠道
  • 行为随类型或状态变化,且未来可能增加新类型
  • 需要单元测试不同策略,隔离验证

基本上就这些。关键是把“做什么”(策略)和“怎么选”(工厂)分开,主流程只关心“执行”,结构更清晰,也更容易应对变化。

switch if switch 封装 接口 对象 算法

上一篇
下一篇
text=ZqhQzanResources