设计模式-状态模式

概述

状态模式也是一种行为型的设计模式,其最主要的思想是将状态封装到对象中,然后对象的行为依赖于状态,使用Switch语句是有不同的,较少了很多分支语句的使用,可以参考下面的例子,如果使用分支语句会有比较多的判断,但是使用状态模式,就减少了对应的判断,也使得代码在使用的时候会减少出错,因为使用的时候只有切换,不用传具体的状态,不过这个模式的缺点也一眼就可以看出,代码控制性不如分支语句。其主要组成部分是状态接口,具体的状态,状态控制器,用状态控制器控制状态的切换。举例如下


例子:现在有个游戏BOOS的状态有,普通,生气,狂暴三个状态,使用一个状态控制器调用一个方法控BOSS的状态切换。

状态模式

cs 复制代码
using System.Numerics;

internal class Program
{
    private static void Main(string[] args)
    {
        StateControl SC = new StateControl(new CommonState());

        SC.Switch();  //切换到普通状态
        SC.Switch();  //切换到生气状态
        SC.Switch();  //切换到狂暴状态
    }
    public interface IState//状态接口
    {
        void SwitchingStatus(StateControl sc);
    }
    public class CommonState : IState//普通状态
    {
        public void SwitchingStatus(StateControl sc)
        {
            Console.WriteLine("BOOS进入普通状态!");
            sc.SetState(new AngryState());
        }
    }
    public class AngryState : IState//生气状态
    {
        public void SwitchingStatus(StateControl sc)
        {
            Console.WriteLine("BOOS进入生气状态!");
            sc.SetState(new MusthState());
        }
    }
    public class MusthState : IState//狂暴状态
    {
        public void SwitchingStatus(StateControl sc)
        {
            Console.WriteLine("BOOS进入狂暴状态!");
        }
    }
    public class StateControl//状态控制器
    {
        private IState _state;
        public StateControl(IState state)
        {
            _state = state;
        }
        public void SetState(IState state)
        {
            _state = state;
        }
        public void Switch()
        {
            _state.SwitchingStatus(this);
        }
    }
}

运行结果:

BOOS进入普通状态!

BOOS进入生气状态!

BOOS进入狂暴状态!

相关推荐
geovindu29 分钟前
go: Strategy Pattern
开发语言·设计模式·golang·策略模式
jiejiejiejie_2 小时前
Flutter for OpenHarmony 萌系 UI 实战合集:骨架屏 + 引导页一站式指南
flutter·ui·华为
Ulyanov2 小时前
《现代 Python 桌面应用架构实战:PySide6 + QML 从入门到工程化》 开发环境搭建与工具链极简主义 —— 拒绝臃肿,构建工业级基座
开发语言·python·qt·ui·架构·系统仿真
Ulyanov3 小时前
《现代 Python 桌面应用架构实战:PySide6 + QML 从入门到工程化》:QML 声明式语法与霓虹按钮 —— 当 Python 遇见现代美学
开发语言·python·ui·qml·系统仿真·雷达电子对抗仿真
嵌入式学习_force6 小时前
02_state
设计模式·蓝牙
薛定猫AI8 小时前
【深度解析】Open Code Skills 工作流:用知识图谱、Spec 驱动与 UI 设计系统提升 AI Coding Agent 生产力
人工智能·ui·知识图谱
ZC跨境爬虫9 小时前
跟着 MDN 学 HTML day_7:(进阶文本语义标签全覆盖)
前端·javascript·css·ui·html
ZC跨境爬虫9 小时前
跟着 MDN 学 HTML day_6:(HTML文本语义标签全解+lang属性)
前端·ui·html·edge浏览器
qcx239 小时前
Warp源码深度解析(七):Token预算策略——双轨计费、上下文溢出与摘要压缩
人工智能·设计模式·rust·wrap
Ulyanov9 小时前
《现代 Python 桌面应用架构实战:PySide6 + QML 从入门到工程化》:实时时钟与数据驱动 UI —— 从“事件回调”到“状态绑定”的范式跃迁
开发语言·python·qt·ui·架构·交互