Java中23种面试常考的设计模式之策略模式(Strategy)---行为型模式

简介: Java中23种面试常考的设计模式之策略模式(Strategy)---行为型模式

【Java中23种面试常考的设计模式之策略模式(Strategy)---行为型模式】

知识回顾:
>

之前我们讲过的设计模式在这里呦:
【面试最常见的设计模式之单例模式】
【面试最常见的设计模式之工厂模式】
【Java中23种面试常考的设计模式之备忘录模式(Memento)---行为型模式】
【Java中23种面试常考的设计模式之观察者模式(Observer)---行为型模式】
【Java中23种面试常考的设计模式之模板模式(Template)---行为型模式】
【Java中23种面试常考的设计模式之状态模式(State)---行为型模式】
接下来我们要进行学习的是:【Java中23种面试常考的设计模式之策略模式(Strategy)---行为型模式】。

策略模式

策略模式核心思想是:在策略模式中,我们创建表示各种策略的对象和一个行为随着策略对象改变而改变的 context 对象。策略对象改变 context 对象的执行算法。

策略模式VS状态模式

无论是从代码实现上,还是类图,策略模式和状态模式几乎都一样,但他们本质上是有所不同的,策略模式是完成一件事有不同实现方式,不同的行为;但是状态模式是某一个对象对应的不同状态,总体还是完成一件事,这件事中对应着不同的状态,你可以简单的把它理解为它只有一种策略,这种策略下对应着多种状态。

解决的问题

有多种算法相似的情况下,使用 if...else 所带来的复杂和难以维护。

应用策略模式的场景

做同一件事情的不同的行为。

生活中关于策略模式应用的场景

  1. 旅行的出游方式,选择骑自行车、坐汽车,每一种旅行方式都是一个策略。
  2. 会员、普通用户、超级会员等等对应不同的打折策略。
  3. 等等。。。等等。。。。

    生产开发中常用的使用场景

  4. Spring框架中,Resource接口,资源访问策略

  5. 解决一道算法题目的不同策略。
  6. 等等。。。。。等等。。。。

策略模式优点与缺点

优点

  1. 算法可以自由切换。
  2. 避免使用多重条件判断。
  3. 扩展性良好。

缺点

  1. 策略类会越来越多,后期不利于管理与维护。
  2. 所有策略类都需要对外暴露,不够安全。

核心角色

定义规则接口的Strategy,实现规则接口策略的具体的类,以及使用某种策略的类Context。

UML类图

image.png

实现代码

我们举这样一个栗子:一场算法竞赛中,有一道题目非常有意思,有多种解法:假设:解法1:暴力法 解法2:双指针 解法3:线段树

接口策略类

package com.strategy;

interface Strategy {
   
   
   void solveProblemDifferentsMethods();
}

具体实现类1

package com.strategy;

class BFStrategy implements Strategy{
   
   

    @Override
    public void solveProblemDifferentsMethods() {
   
   
        // TODO Auto-generated method stub
        System.out.println("这道题目我使用暴力解法解决啦。。。。BFStrategy");
    }

}

具体实现策略类2

package com.strategy;

class TwoPonterStrategy implements Strategy{
   
   

    @Override
    public void solveProblemDifferentsMethods() {
   
   
        // TODO Auto-generated method stub
        System.out.println("这道题目我使用双指针解法解决啦。。。。TwoPonterStrategy");
    }

}

具体实现策略类3

package com.strategy;

class SegmentTreeStrategy implements Strategy{
   
   

    @Override
    public void solveProblemDifferentsMethods() {
   
   
        // TODO Auto-generated method stub
        System.out.println("这道题目我使用线段树解法解决啦。。。。SegmentTreeStrategy");
    }

}

设置使用策略的类

package com.strategy;

class Context{
   
   

    private Strategy strategy;

    public Context(Strategy strategy){
   
   
      this.strategy = strategy;
    }

   public void exec(){
   
   
        strategy.solveProblemDifferentsMethods();
   }

}

测试代码

package com.strategy;

public class Main {
   
   

    public static void main(String[] args){
   
   
        Strategy strategy=new BFStrategy();
        Context context=new Context(strategy);
        context.exec();
        System.out.println("方案一暴力法成功解决。。。。。");
        strategy=new TwoPonterStrategy();
        context=new Context(strategy);
        context.exec();
        System.out.println("方案二双指针法成功解决。。。。。");
        strategy=new SegmentTreeStrategy();
        context=new Context(strategy);
        context.exec();
        System.out.println("方案一线段树方法成功解决。。。。。");
    }
}

运行结果展示:

image.png

好了,到这里【Java中23种面试常考的设计模式之策略模式(Strategy)---行为型模式】就结束了,23种设计模式持续更新汇总中。

相关文章
|
14天前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
45 2
|
2天前
|
Java 程序员
Java社招面试题:& 和 && 的区别,HR的套路险些让我翻车!
小米,29岁程序员,分享了一次面试经历,详细解析了Java中&和&&的区别及应用场景,展示了扎实的基础知识和良好的应变能力,最终成功获得Offer。
24 14
|
19天前
|
存储 算法 Java
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
本文详解自旋锁的概念、优缺点、使用场景及Java实现。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
|
24天前
|
存储 缓存 Oracle
Java I/O流面试之道
NIO的出现在于提高IO的速度,它相比传统的输入/输出流速度更快。NIO通过管道Channel和缓冲器Buffer来处理数据,可以把管道当成一个矿藏,缓冲器就是矿藏里的卡车。程序通过管道里的缓冲器进行数据交互,而不直接处理数据。程序要么从缓冲器获取数据,要么输入数据到缓冲器。
Java I/O流面试之道
|
20天前
|
存储 缓存 Java
大厂面试必看!Java基本数据类型和包装类的那些坑
本文介绍了Java中的基本数据类型和包装类,包括整数类型、浮点数类型、字符类型和布尔类型。详细讲解了每种类型的特性和应用场景,并探讨了包装类的引入原因、装箱与拆箱机制以及缓存机制。最后总结了面试中常见的相关考点,帮助读者更好地理解和应对面试中的问题。
43 4
|
21天前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
72 4
|
2月前
|
存储 Java 程序员
Java面试加分点!一文读懂HashMap底层实现与扩容机制
本文详细解析了Java中经典的HashMap数据结构,包括其底层实现、扩容机制、put和查找过程、哈希函数以及JDK 1.7与1.8的差异。通过数组、链表和红黑树的组合,HashMap实现了高效的键值对存储与检索。文章还介绍了HashMap在不同版本中的优化,帮助读者更好地理解和应用这一重要工具。
55 5
|
2月前
|
存储 Java
[Java]面试官:你对异常处理了解多少,例如,finally中可以有return吗?
本文介绍了Java中`try...catch...finally`语句的使用细节及返回值问题,并探讨了JDK1.7引入的`try...with...resources`新特性,强调了异常处理机制及资源自动关闭的优势。
23 1
|
2月前
|
设计模式 Java 程序员
[Java]23种设计模式
本文介绍了设计模式的概念及其七大原则,强调了设计模式在提高代码重用性、可读性、可扩展性和可靠性方面的作用。文章还简要概述了23种设计模式,并提供了进一步学习的资源链接。
46 0
[Java]23种设计模式
|
17天前
|
设计模式 JavaScript Java
Java设计模式:建造者模式详解
建造者模式是一种创建型设计模式,通过将复杂对象的构建过程与表示分离,使得相同的构建过程可以创建不同的表示。本文详细介绍了建造者模式的原理、背景、应用场景及实际Demo,帮助读者更好地理解和应用这一模式。