有限状态机

转载 2013年12月04日 09:22:53
 

有限状态机

分类: C/C++ 442人阅读 评论(0) 收藏 举报
有限状态机是一种数学概念,运用到程序中,可用于有限数量的状态的变化,每个子程序进行一些处理并选择下一种状态。

基本的实现思路就是用一张表保存所有可能的状态,并列出进入每个状态时可能执行的所有动作,其中最后一个动作就是计算下一个应该进入的状态。运行状态就是从初始状态开始,不停的在各个状态之间转换,直到结束状态。


FSM的实现方式:
1) switch/case或者if/else

这无意是最直观的方式,使用一堆条件判断,会编程的人都可以做到,对简单小巧的状态机来说最合适,但是毫无疑问,这样的方式比较原始,对庞大的状态机难以维护。


2) 状态表

维护一个二维状态表,横坐标表示当前状态,纵坐标表示输入,表中一个元素存储下一个状态和对应的操作。这一招易于维护,但是运行时间和存储空间的代价较大。


3) 使用State Pattern

使用State Pattern使得代码的维护比switch/case方式稍好,性能上也不会有很多的影响,但是也不是100%完美。不过Robert C. Martin做了两个自动产生FSM代码的工具,for java和for C++各一个,在http://www.objectmentor.com/resources/index上有免费下载,这个工具的输入是纯文本的状态机描述,自动产生符合State Pattern的代码,这样developer的工作只需要维护状态机的文本描述,每必要冒引入bug的风险去维护code。


4) 使用宏定义描述状态机
一般来说,C++编程中应该避免使用#define,但是这主要是因为如果用宏来定义函数的话,很容易产生这样那样的问题,但是巧妙的使用,还是能够产生奇妙的效果。MFC就是使用宏定义来实现大的架构的。

在实现FSM的时候,可以把一些繁琐无比的if/else还有花括号的组合放在宏中,这样,在代码中可以3)中状态机描述文本一样写,通过编译器的预编译处理产生1)一样的效果,我见过产生C代码的宏,如果要产生C++代码,己软MFC可以,那么理论上也是可行的。


密码锁的例子

  1. #include <stdio.h>    
  2. #include <stdlib.h>    
  3. #include <string.h>     
  4.   
  5. typedef enum{     
  6.     STATE0 = 0,     
  7.     STATE1,     
  8.     STATE2,    
  9.     STATE3,     
  10.     STATE4,    
  11. }STATE;  
  12.     
  13.   
  14. int main()     
  15.   
  16. {     
  17.     char ch;   
  18.     STATE current_state = STATE0;      
  19.     while(1){     
  20.         printf("In put password:");     
  21.         while((ch = getchar()) != '\n')  
  22.         {     
  23.             if((ch < '0') || (ch > '9'))  
  24.             {     
  25.                 printf("Input num,ok?/n");     
  26.                 break;     
  27.             }     
  28.             switch(current_state){     
  29.             case STATE0:     
  30.                 if(ch == '2')   current_state = STATE1;     
  31.                 break;     
  32.             case STATE1:     
  33.                 if(ch == '4')   current_state = STATE2;     
  34.                 break;     
  35.             case STATE2:     
  36.                 if(ch == '7')   current_state = STATE3;     
  37.                 break;     
  38.             case STATE3:     
  39.                 if(ch == '9')   current_state = STATE4;     
  40.                 break;     
  41.             default:     
  42.                 current_state = STATE0;     
  43.                 break;     
  44.             }     
  45.         }     
  46.   
  47.         if(current_state == STATE4){     
  48.             printf("Correct, lock is open!\n");     
  49.             current_state =   STATE0;  
  50.               
  51.         }else  
  52.         {  
  53.             printf("Wrong, locked!\n");     
  54.             current_state =   STATE0;  
  55.               
  56.         }  
  57.         break;  
  58.     }     
  59.     return 0;     
  60.   
  61. }   

有限状态机的实现

有限状态机(Finite State Machine或者Finite State Automata)是软件领域中一种重要的工具,很多东西的模型实际上就是有限状态机。最近看了一些游戏编程AI的材料,感觉...
  • vargas
  • vargas
  • 2006年12月17日 21:24
  • 2007

Unity有限状态机详解

这阵子用到了有限状态机,于是花了一段时间研究了一下。在这里我会详细的讲解有限状态机的原理以及如何编写一个有限状态机。有限状态机算是Unity开发中一个比较重要的技巧了。那什么什么是有限状态机呢?在游戏...
  • tyuiof
  • tyuiof
  • 2016年11月04日 17:34
  • 1938

Unity3D自学笔记——有限状态机(一)框架搭建

框架搭建概念有限状态机(FSM),即在有限的状态里面进行状态的转移,并执行相应状态下的动作。状态机主要要素有 当前状态 当前状态下执行的动作 切换到下一个状态的条件 下一个状态 Animator就...
  • alistair_chow
  • alistair_chow
  • 2016年11月11日 03:56
  • 1453

游戏开发中有限状态机

有限状态机在游戏开发中是经常用到的数学模型,虽然我做的是"万年捕鱼",但是有幸在2014年用Unity开发《怒海潜江》(已经成为线上尸体)中研究学习了有限状态机并且在项目中成功使用,对BOSS状态的控...
  • u011838628
  • u011838628
  • 2016年09月20日 13:32
  • 1143

算法学习笔记(九)有限状态机 FSM 的应用

有限状态机(Finite-state machine)又称有限状态自动机,是表示有限个状态以及在这些状态之间的转移和动作等行为的数学模型。常用与:正则表达式引擎,编译器的词法和语法分析,游戏设计,网络...
  • thisinnocence
  • thisinnocence
  • 2014年11月16日 13:06
  • 3019

Qt有限状态机简单介绍

有限状态机,(英语:Finite-state machine,FSM),又称有限状态自动机,简称状态机,是表示有限个状态以及在这些状态之间的转移和动作等行为的数学模型。————————————————...
  • yuan545
  • yuan545
  • 2016年04月01日 19:38
  • 352

字符串匹配算法-有限状态机

    下面是字符串匹配算法-有限状态机的简单实现。     //产生字符串P的有限机,void X(const string P, int (*prefix)[26]){ int m = P.len...
  • aa2010aa
  • aa2010aa
  • 2009年12月13日 21:44
  • 2539

计算机理论:有限状态机、图灵机到现代计算机

一、有限状态机 引子 让我们先来看几个简单的概念: 状态        -  系统的基本数学特征。 状态机      -  一个离散数学模型。给定一个输入集合,根据对输入的接受...
  • WSN_IPv6
  • WSN_IPv6
  • 2016年08月01日 15:03
  • 1314

LeetCode-Valid Number - 有限状态机 & 正则表达式

牛逼啊,见这种方式的编程,记录下,思路很新颖,非常好。。。。 今天看到了大神的解法(https://github.com/fuwutu/LeetCode/blob/master/Valid%2...
  • xkzju2010
  • xkzju2010
  • 2016年06月22日 10:54
  • 608

游戏开发设计模式之状态模式 & 有限状态机 & c#委托事件(unity3d 示例实现)

说起状态模式游戏开发者们第一个想到的一定是AI的有限状态机FSMs,状态模式确实是实现有限状态机的一种方法。在有限状态机中,一般都是观察者模式与状态模式连用,状态模式把每个状态封装成类,来对每个输入消...
  • wolf96
  • wolf96
  • 2015年10月23日 10:12
  • 6861
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:有限状态机
举报原因:
原因补充:

(最多只允许输入30个字)