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

使用策略模式代替多个ifelse

传统的多个

public class OrderServiceImpl implements IOrderService {
    @Override
    public String handle(OrderDTO dto) {
        String type = dto.getType();
        if ("1".equals(type)) {
            return "处理普通订单";
        } else if ("2".equals(type)) {
            return "处理团购订单";
        } else if ("3".equals(type)) {
            return "处理促销订单";
        }
        return null;
    }
}

为什么非得写的这么臃肿?很多同事会说:“哎呀,没办法呀,业务催的紧,这样开发效率快省事”。的确是句大实话,很多时候业务方确实像催命鬼一样的让你赶工期,想快速实现功能,这样写是最好的选择。

上边的代码看似还算清晰,可如果我告诉你公司订单来源有上百种,你想象一下那种臃肿的if-else,去翻代码时是什么感受?

二、策略模式的实现方式
策略模式是oop中最著名的设计模式之一,是对方法行为的抽象,可以归类为行为设计模式,也是oop中interface经典的应用。其特点简单又实用,是我最喜欢的模式之一。

策略模式定义了一个拥有共同行为的算法族,每个算法都被封装起来,可以互相替换,独立于客户端而变化。

不少人说:Java的设计模式背了很多,可日常还不就是写if-else的业务,根本就不用到。其实不是用不到是没有用到合适的位置!

策略模式的使用场景:

针对同一问题的多种处理方式,仅仅是具体行为有差别时;
需要安全地封装多种同一类型的操作时;
同一抽象类有多个子类,而客户端需要使用if-else 或者 switch-case 来选择具体子类时。

1定义一个接口
在这里插入图片描述
有多个方法去继承实现
创建工厂
在这里插入图片描述
策略模式的优缺点
优点

易于扩展,增加一个新的策略只需要添加一个具体的策略类即可,基本不需要改变原有的代码,符合开放封闭原则
避免使用多重条件选择语句,充分体现面向对象设计思想 策略类之间可以自由切换,由于策略类都实现同一个接口,所以使它们之间可以自由切换
每个策略类使用一个策略类,符合单一职责原则 客户端与策略算法解耦,两者都依赖于抽象策略接口,符合依赖反转原则
客户端不需要知道都有哪些策略类,符合最小知识原则
缺点

策略模式,当策略算法太多时,会造成很多的策略类
客户端不知道有哪些策略类,不能决定使用哪个策略类,这点可以通过封装common公共包解决,也可以考虑使IOC容器和依赖注入的方式来解决


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

相关文章:

  • 基于SSM+微信小程序的快递的管理系统(快递1)(源码+sql脚本+视频导入教程+文档)
  • CannotAcquireLockException产生原因及解决方案
  • apache的主要目录结构及常见的配置选项的详细说明(图例展示)
  • linux 系统性能调优技巧总结汇总
  • 视频转音频mp3软件有哪些?分享好用的转换工具
  • Mysql语句性能优化
  • YOLO与PyQt5结合-增加论文工作量-实现一个目标检测的UI界面
  • fork exec cow
  • 2 自研rk3566/rk3588+rgbd相机之设备树文件配置
  • 基于GPT回答:结合不同专业,论述GIS应用的关键技术问题
  • Selenium + Python 自动化测试23(综合实战)
  • shell程序设计入门(四)
  • ZooKeeper的节点上下线感知
  • 如何考取PostgreSQL认证证书?
  • 【网络安全】XML-RPC漏洞之盲SSRF
  • 【Electron】Electron学习笔记
  • Spring Boot如何压缩Json并写入redis?
  • 使用Blender进行3D建模—基础操作笔记
  • 小程序面试题一
  • 【Docker】Docker学习04 | dockerfile的编写