文档章节

有限状态机(FSM)

tingliang0
 tingliang0
发布于 2017/06/14 17:36
字数 259
阅读 14
收藏 0

规则:

  1. 拥有一组状态,并且可以在这组状态之间进行切换。
  2. 状态机同一时刻只能处于一种状态。
  3. 状态机会接收一组输入或者事件。
  4. 每一个状态有一组转换,每一个转换都关联着一个输入并指向另一个状态。

简而言之,整个状态机可以分为:状态、输入和转换。

实现1:枚举和分支

可以使用枚举来表示状态,并且使用分支来进行状态切换。

enum State {
    STATE_STANDING,
    STATE_JUMPING,
    STATE_DUCKING,
    STATE_DIVING
};

enum Input {
    PRESS_A,
    PRESS_B
};

class Hero {
    private state: State;
    constructor(parameters) {

    }

    handleInput(input: Input): void {
        switch (this.state) {
            case State.STATE_STANDING:
                if (input == Input.PRESS_B) {
                    this.state = State.STATE_JUMPING;
                    // do something
                }
                break;
            case State.STATE_JUMPING:
                if (input == Input.PRESS_A) {
                    this.state = State.STATE_DIVING;
                    // do something
                }
                break;
            // ...
            default:
                break;
        }
    }
}

FSM适用场景:

  1. 你有一个游戏实体,它的行为基于它的内部状态而改变。
  2. 这些状态被严格划分为相对数目较少的小集合。
  3. 游戏实体随着时间的变化会响应用户输入和一些游戏事件。

© 著作权归作者所有

共有 人打赏支持
上一篇: mongodb常用命令
下一篇: node.js与uuid
tingliang0
粉丝 0
博文 5
码字总数 636
作品 0
广州
私信 提问
有限状态机(FSM)的设计与实现(一)

有限状态机(FSM)是表示有限个状态及在这些状态之间的转移和动作等行为的数学模型,在计算机领域有着广泛的应用。通常FSM包含几个要素:状态的管理、状态的监控、状态的触发、状态触发后引发...

j_m
2012/10/11
0
0
Golang: 有限状态自动机

有限状态机 又简称FSM(Finite-State Machine的首字母缩写)。这个在离散数学里学过了,它是计算机领域中被广泛使用的数学概念。是表示有限个状态以及在这些状态之间的转移和动作等行为的数学模...

陈亦
2014/02/24
1K
5
基于C语言的状态机实现技术

基于C语言的状态机实现技术 嵌入式开发交流群280352802,欢迎加入! 一、简介 有限状态机是一种用来进行对象行为建模的工具,其作用主要是描述对象在它的生命周期内所经历的状态序列,以及如...

长平狐
2013/06/03
852
0
[PHP打野] 对pear-FSM的研究(一)基本了解

FSM(有限状态机)是啥? 有限状态机(英语:finite-state machine,缩写:FSM)又称有限状态自动机,简称状态机,是表示有限个状态以及在这些状态之间的转移和动作等行为的数学模型。 详细请...

梅开源
2014/12/03
0
0
JavaScript与有限状态机

有限状态机(Finite-state machine)是一个非常有用的模型,可以模拟世界上大部分事物。 简单说,它有三个特征:    状态总数(state)是有限的。    任一时刻,只处在一种状态之中。  ...

阮一峰
2013/09/02
0
0

没有更多内容

加载失败,请刷新页面

加载更多

new Date() 在Safari下的 Invalid Date问题

问题复现 var timeStr = '2018-11-11 00:00:00';var time = new Date(timeStr);// error: Invalid Date... 在safari浏览器下,time为Invalid Date, 导致后面代码执行错误; 其他浏览器诸...

会写代码的husky
26分钟前
2
0
0009-如何升级Cloudera Manager和CDH

1.文档编写目的 本文档讲述如何升级Cloudera Manager和CDH,通过本文档,您将学习到以下知识: 1.如何对Cloudera Manager进行停机升级 2.如何对CDH进行停机升级 3.如何在不影响集群作业的情况...

Hadoop实操
36分钟前
1
0
vue2中引用 better-scroll的方法

文章主要介绍了vue2中引用better-scroll和使用 better-scroll的方法,使用时有三个要点及注意事项在文中给大家详细介绍 ,需要的朋友可以参考下 使用时有三个要点: 一:html部分 <div class...

前端攻城老湿
46分钟前
1
0
浅谈教你如何掌握Linux系统

linux能做什么?相信绝大数人都有这样的疑问。可以玩吃鸡吗?可以玩lol吗? 如果你是以娱乐的名义来评价linux的可用性,对不起,linux可能不适合你,因为linux是一个工具,他是教你聪明的,不...

linuxprobe16
52分钟前
1
0
java中线程池的生命周期

线程池生命周期包括: RUNNING:接收新的任务并处理队列中的任务 SHUTDOWN:不接收新的任务,但是处理队列中的任务 STOP:不接收新的任务,不处理队列中的任务,同时中断处理中的任务 TIDYING:所...

小刀爱编程
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部