【设计模式】策略模式在数据接收和发送场景的应用

简介: 在数据接收和发送场景打算使用了if else进行判断。ASystem.sync("向A同步数据");BSystem.sync("向B同步数据");...非常麻烦,需求多了很臃肿!策略模式(Strategy Pattern)定义了一组同类型的算法,在不同的类中封装起来,每种算法可以根据当前场景相互替换,从而使算法的变化独立于使用它们的客户端(即算法的调用者)。// 创建两个策略对象// 创建上下文对象,并传入策略对象。

其他系列文章导航

Java基础合集

数据结构与算法合集

设计模式合集

多线程合集

分布式合集

ES合集


文章目录

其他系列文章导航

文章目录

前言

一、策略模式改进

1.1 策略模式的定义:

1.2 策略模式的结构通常包括以下组成部分:

1.3 根据上面的结构,我们来实现一下我们的场景。

1.3.1 我们需要定义一个策略接口,定义与外部系统间交互都需要实现的方法

1.3.2 为每个外部系统创建一个策略类:

1.3.3 创建一个选择外部系统的策略类,用于在运行时根据需要选择合适的策略类

1.3.4 最后,在需要调用外部系统同步数据的地方实例化相关策略类和上下文类,并调用executeStrategy方法

二、升级为策略模式+工厂模式

三、总结


前言

在数据接收和发送场景打算使用了 if else 进行判断。

代码如下:

if("A".equals(system)){
    ASystem.sync("向A同步数据");
}
if("B".equals(system)){
    BSystem.sync("向B同步数据");
}
...

image.gif

非常麻烦,需求多了很臃肿


一、策略模式改进

1.1 策略模式的定义:

策略模式(Strategy Pattern)定义了一组同类型的算法,在不同的类中封装起来,每种算法可以根据当前场景相互替换,从而使算法的变化独立于使用它们的客户端(即算法的调用者)。

1.2 策略模式的结构通常包括以下组成部分:

    1. 定义一个策略接口或抽象类:该接口或抽象类定义了所有策略类都需要实现的方法。
    2. 创建多个具体的策略类:每个具体的策略类都实现了策略接口或抽象类,并提供了不同的实现。
    3. 创建一个策略上下文类:该类负责使用策略,它通常会维护一个策略接口或抽象类的引用。
    4. 在客户端代码中使用策略上下文类:客户端代码可以根据需要选择不同的策略。

    看定义有些抽象,下面的结构图应该会容易理解一些:

    image.gif编辑

    1.3 根据上面的结构,我们来实现一下我们的场景。

    1.3.1 我们需要定义一个策略接口,定义与外部系统间交互都需要实现的方法

    代码如下:

    public interface DataProcessingStrategy {
        void receiveData();
        void sendData();
    }

    image.gif

    1.3.2 为每个外部系统创建一个策略类:

    ASystem:

    代码如下:

    public class ASystemDataProcessingStrategy implements DataProcessingStrategy {
        @Override
        public void receiveData() {
            // 接收数据的具体实现
        }
        @Override
        public void sendData() {
            // 发送数据的具体实现
        }
    }

    image.gif

    BSystem:

    代码如下:

    public class BSystemDataProcessingStrategy implements DataProcessingStrategy {
        @Override
        public void receiveData() {
            // 接收数据的具体实现
        }
        @Override
        public void sendData() {
            // 发送数据的具体实现
        }
    }

    image.gif

    1.3.3 创建一个选择外部系统的策略类,用于在运行时根据需要选择合适的策略类

    代码如下:

    public class Context {
        private DataProcessingStrategy strategy;
        public Context(DataProcessingStrategy strategy) {
            this.strategy = strategy;
        }
        public void setStrategy(DataProcessingStrategy strategy) {
            this.strategy = strategy;
        }
        public void sendData(String data) {
            strategy.sendData(data);
        }
        public String receiveData() {
            return strategy.receiveData();
        }
    }

    image.gif

    1.3.4 最后,在需要调用外部系统同步数据的地方实例化相关策略类和上下文类,并调用executeStrategy方法

    代码如下:

    public class Main {
        public static void main(String[] args) {
            // 创建两个策略对象
            DataProcessingStrategy strategyA = new ASystemDataProcessingStrategy();
            DataProcessingStrategy strategyB = new BSystemDataProcessingStrategy();
            // 创建上下文对象,并传入策略对象
            Context context = new Context(strategyA);
            //使用 ASystemDataProcessingStrategy 请求和接收数据
            context.sendData("");  
            context.receiveData("");
            // 使用 BSystemDataProcessingStrategy 请求和接收数据
            context = new Context(strategyB);
            context.sendData("");  
            context.receiveData("");
        }
    }

    image.gif


    二、升级为策略模式+工厂模式

    那么策略模式存在什么样的问题呢?

      1. 硬编码的依赖关系:在上述代码中,我们直接将具体的策略类(例如StrategyA和StrategyB)硬编码到上下文类(Context)中。这意味着如果我们想要添加或修改策略,我们需要在上下文类中修改代码。这种硬编码的方式使得系统难以扩展和维护。
      2. 客户端与策略的具体实现紧密耦合:由于上下文类Context直接依赖于具体的策略类,因此客户端代码必须了解每个具体策略的细节。这增加了客户端代码的复杂性,并使得客户端代码与策略的具体实现紧密耦合,增加了代码的维护难度。

      我们可以使用工厂模式来改进我们的设计。工厂模式可以帮助我们将对象的创建和使用过程分离,使得上下文类和客户端代码不需要了解具体策略的细节,那么我们来修改一下我们的实现:

      context可以去除

      代码如下:

      // 策略接口和具体的策略类保持不变
      public interface DataProcessingStrategy {
          void sendData(String data);
          String receiveData();
      }
      public class ASystemDataProcessingStrategy implements DataProcessingStrategy {
          @Override
          public void sendData(String data) {
              // 发送数据到系统A的实现
          }
          @Override
          public String receiveData() {
              // 从系统A接收数据的实现
          }
      }
      public class BSystemDataProcessingStrategy implements DataProcessingStrategy {
          @Override
          public void sendData(String data) {
              // 发送数据到系统B的实现
          }
          @Override
          public String receiveData() {
              // 从系统B接收数据的实现
          }
      }
      public class DataProcessingStrategyFactory {
         private static ConcurrentHashMap<String, DataProcessingStrategy> strategies = new ConcurrentHashMap<>();
         /**
          * 注册策略
          * @param strategyName
          * @param strategy
          */
         public static void register(String strategyName, DataProcessingStrategy strategy) {
             strategies.put(strategyName, strategy);
        }
         public static DataProcessingStrategy getStrategy(String strategyName) {
             return strategies.get(strategyName);
        }
      }
      //client类相关修改
      public class Main {
          public static void main(String[] args) {
              DataProcessingStrategy systemA = DeployStrategyFactory.getStrategy("A");
              //使用 ASystemDataProcessingStrategy 请求和接收数据
              systemA.sendData("");  
              systemA.receiveData("");
              DataProcessingStrategy systemB = DeployStrategyFactory.getStrategy("B");
              // 使用 BSystemDataProcessingStrategy 请求和接收数据
              systemB.sendData("");  
              systemB.receiveData("");
          }
      }

      image.gif


      三、总结

      在本篇文章中,我们介绍了策略模式,并在数据接收和发送场景中使用了策略模式。

      通过使用策略模式,我们可以在客户端代码中根据运行时条件动态地选择一个具体的策略类,并通过这个策略类来改变对象的行为。

      这样,我们就可以实现不同的数据接收和发送方式,而不需要在客户端代码中进行大量的if-else判断。

      同时通过策略模式+工厂模式的方式解决了客户端代码与策略的具体实现紧密耦合的问题。

      当然结合实际的场景灵活运用相应的设计模式也非常重要,避免过度设计

      目录
      相关文章
      |
      2月前
      |
      设计模式 算法 Kotlin
      Kotlin - 改良设计模式 - 策略模式
      Kotlin - 改良设计模式 - 策略模式
      55 4
      |
      9天前
      |
      设计模式 存储 缓存
      前端必须掌握的设计模式——策略模式
      策略模式(Strategy Pattern)是一种行为型设计模式,旨在将多分支复杂逻辑解耦。每个分支类只关心自身实现,无需处理策略切换。它避免了大量if-else或switch-case代码,符合开闭原则。常见应用场景包括表单验证、风格切换和缓存调度等。通过定义接口和上下文类,策略模式实现了灵活的逻辑分离与扩展。例如,在国际化需求中,可根据语言切换不同的词条包,使代码更加简洁优雅。总结来说,策略模式简化了多条件判断,提升了代码的可维护性和扩展性。
      |
      2月前
      |
      设计模式 算法 Kotlin
      Kotlin教程笔记(53) - 改良设计模式 - 策略模式
      Kotlin教程笔记(53) - 改良设计模式 - 策略模式
      51 1
      |
      2月前
      |
      设计模式 前端开发 JavaScript
      JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式
      本文深入探讨了JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式,结合电商网站案例,展示了设计模式如何提升代码的可维护性、扩展性和可读性,强调了其在前端开发中的重要性。
      44 2
      |
      2月前
      |
      设计模式 监控 算法
      Python编程中的设计模式应用与实践感悟###
      在Python这片广阔的编程疆域中,设计模式如同导航的灯塔,指引着开发者穿越复杂性的迷雾,构建出既高效又易于维护的代码结构。本文基于个人实践经验,深入探讨了几种核心设计模式在Python项目中的应用策略与实现细节,旨在为读者揭示这些模式背后的思想如何转化为提升软件质量的实际力量。通过具体案例分析,展现了设计模式在解决实际问题中的独特魅力,鼓励开发者在日常编码中积极采纳并灵活运用这些宝贵的经验总结。 ###
      |
      2月前
      |
      设计模式 算法 Kotlin
      Kotlin教程笔记(53) - 改良设计模式 - 策略模式
      Kotlin教程笔记(53) - 改良设计模式 - 策略模式
      52 2
      |
      2月前
      |
      设计模式 开发者 Python
      Python编程中的设计模式应用与实践感悟####
      本文作为一篇技术性文章,旨在深入探讨Python编程中设计模式的应用价值与实践心得。在快速迭代的软件开发领域,设计模式如同导航灯塔,指引开发者构建高效、可维护的软件架构。本文将通过具体案例,展现设计模式如何在实际项目中解决复杂问题,提升代码质量,并分享个人在实践过程中的体会与感悟。 ####
      |
      2月前
      |
      设计模式 存储 数据库连接
      PHP中的设计模式:单例模式的深入理解与应用
      【10月更文挑战第22天】 在软件开发中,设计模式是解决特定问题的通用解决方案。本文将通过通俗易懂的语言和实例,深入探讨PHP中单例模式的概念、实现方法及其在实际开发中的应用,帮助读者更好地理解和运用这一重要的设计模式。
      25 1
      |
      3月前
      |
      设计模式 测试技术 持续交付
      架构视角下的NHibernate:设计模式与企业级应用考量
      【10月更文挑战第13天】随着软件开发向更复杂、更大规模的应用转变,数据访问层的设计变得尤为重要。NHibernate作为一个成熟的对象关系映射(ORM)框架,为企业级.NET应用程序提供了强大的支持。本文旨在为有一定经验的开发者提供一个全面的指南,介绍如何在架构层面有效地使用NHibernate,并结合领域驱动设计(DDD)原则来构建既强大又易于维护的数据层。
      48 2
      |
      3月前
      |
      设计模式 开发者 Python
      Python编程中的设计模式应用与实践###
      【10月更文挑战第18天】 本文深入探讨了Python编程中设计模式的应用与实践,通过简洁明了的语言和生动的实例,揭示了设计模式在提升代码可维护性、可扩展性和重用性方面的关键作用。文章首先概述了设计模式的基本概念和重要性,随后详细解析了几种常用的设计模式,如单例模式、工厂模式、观察者模式等,在Python中的具体实现方式,并通过对比分析,展示了设计模式如何优化代码结构,增强系统的灵活性和健壮性。此外,文章还提供了实用的建议和最佳实践,帮助读者在实际项目中有效运用设计模式。 ###
      33 0