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

当代码中出现大量 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 判断被收拢到工厂内部,甚至可以用配置或映射表替代,后期扩展只需注册新策略,不改动核心逻辑。
优势与适用场景
这种组合特别适合:
多分支业务规则,如支付方式、审批流程、消息通知渠道 行为随类型或状态变化,且未来可能增加新类型 需要单元测试不同策略,隔离验证
基本上就这些。关键是把“做什么”(策略)和“怎么选”(工厂)分开,主流程只关心“执行”,结构更清晰,也更容易应对变化。
以上就是如何运用策略模式与工厂模式优化复杂的条件判断逻辑?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1522545.html
微信扫一扫
支付宝扫一扫