设计模式-状态模式

概述

状态模式也是一种行为型的设计模式,其最主要的思想是将状态封装到对象中,然后对象的行为依赖于状态,使用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进入狂暴状态!

相关推荐
我命由我123454 小时前
Photoshop - Ps还原和历史记录
学习·ui·职场和发展·求职招聘·职场发展·学习方法·photoshop
我命由我123454 小时前
Photoshop - Ps工作界面
学习·ui·职场和发展·求职招聘·职场发展·学习方法·photoshop
sg_knight5 小时前
适配器模式(Adapter)
python·设计模式·适配器模式·adapter
a1117765 小时前
卡通风格 UI 组件库html (TRIZ UI Kit [特殊字符])
前端·ui·html
郝学胜-神的一滴9 小时前
Effective Modern C++ 条款40:深入理解 Atomic 与 Volatile 的多线程语义
开发语言·c++·学习·算法·设计模式·架构
九狼11 小时前
Riverpod 2.0 代码生成与依赖注入
flutter·设计模式·github
菜鸟小芯12 小时前
【GLM-5 陪练式创意 UI 实战】第一篇:创意魔法盒 —— 用 AI 生成 “开心” 主题 Flutter UI,搞定深浅色与响应式
人工智能·flutter·ui
geovindu12 小时前
python: Visitor Pattern
python·设计模式·访问者模式
五阿哥永琪13 小时前
常见设计模式简介
设计模式
木斯佳13 小时前
前端八股文面经大全:字节跳动前端一面(2025-10-09)·面经深度解析
前端·状态模式