笨蛋学设计模式行为型模式-状态模式【20】

2024-01-22 16:04

本文主要是介绍笨蛋学设计模式行为型模式-状态模式【20】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

行为型模式-状态模式

    • 8.7状态模式
      • 8.7.1概念
      • 8.7.2场景
      • 8.7.3优势 / 劣势
      • 8.7.4状态模式可分为
      • 8.7.5状态模式
      • 8.7.6实战
        • 8.7.6.1题目描述
        • 8.7.6.2输入描述
        • 8.7.6.3输出描述
        • 8.7.6.4代码
      • 8.7.7总结

8.7状态模式

8.7.1概念

​ 状态模式是指对象在运行时可以根据内部状态的不同而改变它们的行为,该模式将内部状态的行为封装为不同的具体状态类中,并将状态转换逻辑委托给这些状态类来处理,当对象的内部状态发生变化时,它会自动切换到对应的状态类,从而改变其行为。

8.7.2场景

​ 比如在设计一个电梯系统时,可以使用状态模式来管理电梯的不同状态,如开门、关门、上升、下降等。将电梯的这几种状态封装成一个独立的状态类,并定义了该状态下的具体行为,通过将状态切换的逻辑分布到各个状态类中,可以使得电梯的状态切换更加清晰、易于维护和扩展。

8.7.3优势 / 劣势

  • 代码结构清晰:将每个状态切换的逻辑都封装到各个独立的状态类中,使得代码更加清晰
  • 遵循开闭原则:通过新增一个新的状态类,可以轻松地扩展系统的功能

  • 代码可能过于冗余:若状态类过多或者状态转移过于复杂,会导致系统的类数量增加
  • 过于抽象:状态模式比较抽象,不太容易理解

8.7.4状态模式可分为

  • 状态State:定义一个接口,用于封装与Context的一个特定状态相关的行为
  • 具体状态ConcreteState:负责处理Context在状态改变时的行为,每一个具体状态子类实现一个与Context的一个状态相关的行为
  • 上下文Context:维护一个具体状态子类的实例,这个实例定义当前的状态

8.7.5状态模式

package com.technologystatck.designpattern.mode.state;public class States {public static void main(String[] args) {Context context = new Context();State state1 = new ConcreteState1();State state2 = new ConcreteState2();context.setState(state1);//执行在状态1下的操作context.request();context.setState(state2);//执行在状态2下的操作context.request();}
}//定义状态接口
interface State{void handle();
}//实现具体状态类:为对象可能的每种状态创建具体的状态类,
//实现状态接口中定义的方法//具体状态类1
class ConcreteState1 implements State{@Overridepublic void handle() {//执行在状态1下的操作System.out.println("执行在状态1下的操作");}
}
//具体状态类2
class ConcreteState2 implements State{@Overridepublic void handle() {//执行在状态2下的操作System.out.println("执行在状态2下的操作");}
}
//创建上下文类:该类包含对状态的引用,并在需要时调用当前状态的方法
class Context{private State currentState;//根据不同的状态类,调用不同的状态类方法public void setState(State state){this.currentState=state;}public void request(){currentState.handle();  //调用状态对象中的方法,完成状态的转换}
}

8.7.6实战

8.7.6.1题目描述

小明家有一个灯泡,刚开始为关闭状态(OffState)。台灯可以接收一系列的指令,包括打开(“ON”)、关闭(“OFF”)和闪烁(“blink”)。每次接收到一个指令后,台灯会执行相应的操作,并输出当前灯泡的状态。请设计一个程序模拟这个灯泡系统。

8.7.6.2输入描述

第一行是一个整数 n(1 <= n <= 1000),表示接收的命令数量。

接下来的 n 行,每行包含一个字符串 s,表示一个命令(“ON”、“OFF"或"blink”)。

8.7.6.3输出描述

对于每个命令,输出一行,表示执行该命令后灯泡的状态。

8.7.6.4代码
package com.technologystatck.designpattern.mode.state;import java.util.Scanner;public class Test {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int nums = scanner.nextInt();scanner.nextLine();//实例化灯泡类Light light = new Light();for (int i = 0; i < nums; i++) {String command = scanner.nextLine().trim();//根据输入修改灯的状态switch (command) {//根据不同的状态使用不同的灯泡case "ON":light.setState(new OnBulbState());break;case "OFF":light.setState(new OffBulbState());break;case "BLINK":light.setState(new BlinkBulbState());break;default:System.out.println("Invalid command: "+command);break;}//显示灯的当前状态System.out.println(light.performOperation());}}
}//定义状态接口
interface TableLampState {String handle();
}//定义具体的状态类
//打开台灯
class OnBulbState implements TableLampState {@Overridepublic String handle() {return "Light is ON";}
}//关闭台灯
class OffBulbState implements TableLampState {@Overridepublic String handle() {return "Light is OFF";}
}//台灯闪烁
class BlinkBulbState implements TableLampState {@Overridepublic String handle() {return "Light is Blink";}
}//上下文类
class Light {//当前状态类的状态private TableLampState state;public Light() {//初始状态为关闭this.state = new OffBulbState();}//设置新的状态public void setState(TableLampState state) {this.state = state;}//执行状态转换public String performOperation() {return state.handle();}
}

8.7.7总结

  • 优点:状态模式使的代码结构更加清晰化,同时更方便我们对代码结构进行扩展
  • 总结:将对象的每个状态封装成一个类,通过给类增加对应状态的行为,来实现对象的状态操作
  • 场景:适用于有限状态机的场景,其中对象的行为在运行时可以根据内部的状态改变而改变

这篇关于笨蛋学设计模式行为型模式-状态模式【20】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/633481

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

hdu1565(状态压缩)

本人第一道ac的状态压缩dp,这题的数据非常水,很容易过 题意:在n*n的矩阵中选数字使得不存在任意两个数字相邻,求最大值 解题思路: 一、因为在1<<20中有很多状态是无效的,所以第一步是选择有效状态,存到cnt[]数组中 二、dp[i][j]表示到第i行的状态cnt[j]所能得到的最大值,状态转移方程dp[i][j] = max(dp[i][j],dp[i-1][k]) ,其中k满足c

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

状态dp总结

zoj 3631  N 个数中选若干数和(只能选一次)<=M 的最大值 const int Max_N = 38 ;int a[1<<16] , b[1<<16] , x[Max_N] , e[Max_N] ;void GetNum(int g[] , int n , int s[] , int &m){ int i , j , t ;m = 0 ;for(i = 0 ;

hdu3006状态dp

给你n个集合。集合中均为数字且数字的范围在[1,m]内。m<=14。现在问用这些集合能组成多少个集合自己本身也算。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.Inp

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

实例:如何统计当前主机的连接状态和连接数

统计当前主机的连接状态和连接数 在 Linux 中,可使用 ss 命令来查看主机的网络连接状态。以下是统计当前主机连接状态和连接主机数量的具体操作。 1. 统计当前主机的连接状态 使用 ss 命令结合 grep、cut、sort 和 uniq 命令来统计当前主机的 TCP 连接状态。 ss -nta | grep -v '^State' | cut -d " " -f 1 | sort |

【C++学习笔记 20】C++中的智能指针

智能指针的功能 在上一篇笔记提到了在栈和堆上创建变量的区别,使用new关键字创建变量时,需要搭配delete关键字销毁变量。而智能指针的作用就是调用new分配内存时,不必自己去调用delete,甚至不用调用new。 智能指针实际上就是对原始指针的包装。 unique_ptr 最简单的智能指针,是一种作用域指针,意思是当指针超出该作用域时,会自动调用delete。它名为unique的原因是这个

模版方法模式template method

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/template-method 超类中定义了一个算法的框架, 允许子类在不修改结构的情况下重写算法的特定步骤。 上层接口有默认实现的方法和子类需要自己实现的方法