登录
首页 >  文章 >  前端

策略与工厂模式优化判断逻辑详解

时间:2025-11-10 23:57:52 260浏览 收藏

小伙伴们有没有觉得学习文章很有意思?有意思就对了!今天就给大家带来《策略模式与工厂模式优化条件判断逻辑》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

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

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

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

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

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

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

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

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

工厂模式:解耦对象创建

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

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

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

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

实际调用流程如下:

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

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

优势与适用场景

这种组合特别适合:

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

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

到这里,我们也就讲完了《策略与工厂模式优化判断逻辑详解》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于工厂模式,策略模式的知识点!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>