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

策略模式

什么是策略模式

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

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

优点:

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

缺点:

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

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

案例

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

UML

实现步骤:

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

实现代码

Strategy.java

java 复制代码
// 策略接口
public interface Strategy {
    // 定义操作接口
    int dealOperation(int num1,int num2);
}

OperationAdd.java

java 复制代码
// 具体策略类-加法
public class OperationAdd implements Strategy{
    @Override
    public int dealOperation(int num1, int num2) {
        return num1 + num2;
    }
}

OperationSubtract.java

java 复制代码
// 具体策略类-减法
public class OperationSubtract implements Strategy {
    @Override
    public int dealOperation(int num1, int num2) {
        return num1 - num2;
    }
}

OperationMultiply.java

java 复制代码
// 具体策略类-乘法
public class OperationMultiply implements Strategy {
    @Override
    public int dealOperation(int num1, int num2) {
        return num1 * num2;
    }
}

OperationDivide.java

java 复制代码
// 具体策略类-除法
public class OperationDivide implements Strategy {

    @Override
    public int dealOperation(int num1, int num2) {
        return num1 / num2;
    }
}

Context.java

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);
    }
}

TestClient.java

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));
    }
}

执行结果:

gitee源码

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

相关推荐
晔子yy1 天前
如何设计让你的程序同时处理10w条数据
java
Yvonne爱编码1 天前
链表高频 6 题精讲 | 从入门到熟练掌握链表操作
java·数据结构·链表
lpfasd1231 天前
物联网后端岗位java面试题
java·物联网·php
毕设源码李师姐1 天前
计算机毕设 java 基于 java 的图书馆借阅系统 智能图书馆借阅综合管理平台 基于 Java 的图书借阅与信息管理系统
java·开发语言·课程设计
忆~遂愿1 天前
Runtime 上下文管理:计算实例的生命周期、延迟最小化与上下文切换优化
java·大数据·开发语言·人工智能·docker
powerfulhell1 天前
寒假python作业5
java·前端·python
1尢晞11 天前
Java学习
java·开发语言
阿杰真不会敲代码1 天前
Mybatis-plus入门到精通
java·tomcat·mybatis
木井巳1 天前
【递归算法】二叉搜索树中第K小的元素
java·算法·leetcode·深度优先·剪枝
qq_297574671 天前
【实战】POI 实现 Excel 多级表头导出(含合并单元格完整方案)
java·spring boot·后端·excel