• 03-JAVA设计模式-策略模式


    策略模式

    什么是策略模式

    策略模式(Strategy Pattern)是行为设计模式之一,它使你能在运行时改变对象的行为。在策略模式中,一个类的行为或其算法可以在运行时更改。这种类型的设计模式属于行为模式。

    在策略模式中,我们创建表示各种策略的对象和一个行为随着策略对象改变而改变的上下文对象。策略对象更改上下文对象的执行算法。

    优点:

    • 策略模式提供了管理相关的算法族的办法。策略类的等级结构定义了一个算法族,恰当使用继承可以把公共的代码移到父类里面,从而避免代码重复。
    • 策略模式提供了可以替换继承关系的办法。继承可以处理多种算法或行为。如果不是用策略模式,那么在这些算法或行为特别多的情况下,使用继承方式,会造成子类膨胀,使用策略模式可以避免这个问题。
    • 使用策略模式可以避免使用多重条件转移语句。多重条件转移语句不易维护,它把采取哪一种算法或采取哪一种行为的逻辑与算法或行为的逻辑混合在一起,统统列在一个多重条件选择语句里面,比使用继承的办法还要原始和落后。

    缺点:

    • 客户端必须知道不同策略的存在,并自行决定使用哪一个策略。
    • 策略模式将造成产生很多策略类,增加了代码的复杂性。

    策略模式对应于解决某一个问题的算法族,允许用户从该算法族中任选一个算法解决某一问题,同时可以方便的更换算法或者增加新的算法,并且有客户端决定调用那个算法。

    案例

    使用策略模式,对应两个数进行加减乘除操作

    UML

    在这里插入图片描述

    实现步骤:

    • 定义操作接口,为具体实现算法的创建提供统一的接口类
    • 创建具体的策略类,实现加减乘除不同的算法
    • 创建上限文对象,对象中持有策略算法的引用,提供调用方法,通过持有的策略算法的引用实现不同算法的调用

    实现代码

    Strategy.java

    // 策略接口
    public interface Strategy {
        // 定义操作接口
        int dealOperation(int num1,int num2);
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    OperationAdd.java

    // 具体策略类-加法
    public class OperationAdd implements Strategy{
        @Override
        public int dealOperation(int num1, int num2) {
            return num1 + num2;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    OperationSubtract.java

    // 具体策略类-减法
    public class OperationSubtract implements Strategy {
        @Override
        public int dealOperation(int num1, int num2) {
            return num1 - num2;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    OperationMultiply.java

    // 具体策略类-乘法
    public class OperationMultiply implements Strategy {
        @Override
        public int dealOperation(int num1, int num2) {
            return num1 * num2;
        }
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    OperationDivide.java

    // 具体策略类-除法
    public class OperationDivide implements Strategy {
    
        @Override
        public int dealOperation(int num1, int num2) {
            return num1 / num2;
        }
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    Context.java

    // 上限文类
    public class Context {
    
        private Strategy strategy;
    
        public Context(Strategy strategy) {
            this.strategy = strategy;
        }
    
        public int executeStrategy(int num1, int num2) {
            return strategy.dealOperation(num1, num2);
        }
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    TestClient.java

    public class TestClient {
        public static void main(String[] args) {
            Context context = new Context(new OperationAdd());
            System.out.printf("选择加法-执行结果:%s%n",context.executeStrategy(5,2));
            context = new Context(new OperationMultiply());
            System.out.printf("选择乘法-执行结果:%s%n",context.executeStrategy(5,2));
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    执行结果:

    在这里插入图片描述

    gitee源码

    git clone https://gitee.com/dchh/JavaStudyWorkSpaces.git

  • 相关阅读:
    imu预积分学习(更新中)
    Aspose.PDF for Java Crack by Xacker
    SAR信号处理基础2——线性调频信号频谱与驻定相位原理
    A02-HTML5入门
    服务器部署教程下(线下、线上部署)
    Ubuntu22.04启用root账户 2208120941
    【机器学习大杀器】Stacking堆叠模型-English
    【递归、搜索与回溯算法】第六节.98. 验证二叉搜索树和230. 二叉搜索树中第K小的元素
    Vis.js教程(一):基础教程
    【大数据开发 Spark】第二篇:搭建 Spark 开发环境、 Spark 实现 WordCount 单词统计
  • 原文地址:https://blog.csdn.net/u014331138/article/details/138175398