基于SpringBoot和注解实现策略模式解决重复使用(if--else)的问题

末蓝、 2023-06-23 05:55 104阅读 0赞

应用场景:

实际开发:

最近在项目中遇到一个开发场景,需要根据type值判断来执行对应的业务逻辑,这样就涉及到重复的if-else的问题,为了解决这样重复的代码来造成的代码冗余的问题,所以考虑使用策略模式,根据具体的场景执行对应的策略,来解决问题。本文简单写一个测试Demo,实际开发需要根据具体业务,具体实现对应的业务逻辑。

总结:

因为业务需求需要重复的判断,造成代码冗余。

具体方案(简单Demo):

设计模式:策略模式

常用注解:@Component @Autowried @Service(Bean注解都可以,并非必须用这几个)

开发环境:Spring环境 (Boot最佳)

注意:

  1. bean的名称必须定义,最好根据业务取实际意义的名称,方便代码阅读。
  2. 从Map中寻找对应的策略实现类执行对应方法时应该抓取异常,因为如果没有找到的话,会报异常错误。
  3. 最好使用线程安全的ConcurrentHashMap来装全部的策略实现类,防止出现线程安全问题。

首先创建策略接口

  1. /**
  2. * @author LMY
  3. * @Date 2019/12/17
  4. */
  5. public interface Strategy {
  6. String getMember();
  7. }

实现类实现策略接口

  1. @Component("one")
  2. public class OneStrategy implements Strategy {
  3. @Override
  4. public String getMember() {
  5. return "one";
  6. }
  7. }
  8. @Component("two")
  9. public class TwoStrategy implements Strategy {
  10. @Override
  11. public String getMember() {
  12. return "two";
  13. }
  14. }

创建策略执行器(将实现类注入到公有Map中)

  1. @Service
  2. public class NumberContext {
  3. // 使用线程安全的ConcurrentHashMap
  4. private final Map<String, Strategy> strategyMap = new ConcurrentHashMap<>();
  5. // Autowired注解会自动将实现策略接口的实现类注入到Map中,key就是自定义的Bean的名称
  6. @Autowired
  7. public NumberContext(Map<String, Strategy> strategyMap) {
  8. this.strategyMap.clear();
  9. strategyMap.forEach((k, v)-> this.strategyMap.put(k, v));
  10. }
  11. // 根据传入的标签与Map中的key对比,执行对应的逻辑
  12. public String getResource(String number){
  13. return strategyMap.get(number).getMember();
  14. }
  15. }

编写测试类测试

  1. @RestController
  2. @RequestMapping("test")
  3. public class TestController {
  4. @Autowired
  5. private NumberContext numberContext;
  6. @GetMapping("number")
  7. public String getNumber(String number){
  8. return numberContext.getResource(number);
  9. }
  10. }

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2xzNDkwNDQ3NDA2_size_16_color_FFFFFF_t_70

发表评论

表情:
评论列表 (有 0 条评论,104人围观)

还没有评论,来说两句吧...

相关阅读

    相关 使用注解实现策略模式

    需求描述 现在我们有一个接受供应商订单状态通知的接口,目前支持的功能有退款,改签,后续可能需要接入新功能,比如航变,订单状态改变之类。接口的请求格式一致,接口如下: 请