首页服务器Web服务器 Linux有限状态机FSM的理解与实现

Linux有限状态机FSM的理解与实现

有限状态机(finite state machine)简称FSM,表示有限个状态及在这些状态之间的转移和动作等行为的数学模型,在计算机领域有着广泛的应用。FSM是一种逻辑单元内部的一种高效编程…

有限状态机(finite state machine)简称FSM,表示有限个状态及在这些状态之间的转移和动作等行为的数学模型,在计算机领域有着广泛的应用。FSM是一种逻辑单元内部的一种高效编程方法,在服务器编程中,服务器可以根据不同状态或者消息类型进行相应的处理逻辑,使得程序逻辑清晰易懂。

那有限状态机通常在什么地方被用到?

处理程序语言或者自然语言的 tokenizer,自底向上解析语法的parser,
各种通信协议发送方和接受方传递数据对消息处理,游戏AI等都有应用场景。

状态机有以下几种实现方法,我将一一阐述它们的优缺点。

一、使用if/else if语句实现的FSM
使用if/else if语句是实现的FSM最简单最易懂的方法,我们只需要通过大量的if /else if语句来判断状态值来执行相应的逻辑处理。

看看下面的例子,我们使用了大量的if/else if语句实现了一个简单的状态机,做到了根据状态的不同执行相应的操作,并且实现了状态的跳转。

//比如我们定义了小明一天的状态如下enum{  GET_UP,  GO_TO_SCHOOL,  HAVE_LUNCH,  GO_HOME,  DO_HOMEWORK,  SLEEP,};int main(){  int state = GET_UP;  //小明的一天  while (1)  {    if (state == GET_UP)    {      GetUp(); //具体调用的函数      state = GO_TO_SCHOOL; //状态的转移    }    else if (state == GO_TO_SCHOOL)    {      Go2School();      state = HAVE_LUNCH;    }    else if (state == HAVE_LUNCH)    {      HaveLunch();    }    ...    else if (state == SLEEP)    {      Go2Bed();      state = GET_UP;    }  }  return 0;}
本文来自网络,不代表1号站长-站长学院|资讯交流平台立场。转载请注明出处: https://www.1cn.cc/fwq/web/6266.html
上一篇Centos 7下利用crontab定时执行任务详解
下一篇 Ubuntu系统下用Crontab命令定时执行PHP文件详解
admin

作者: admin

这里可以再内容模板定义一些文字和说明,也可以调用对应作者的简介!或者做一些网站的描述之类的文字或者HTML!

为您推荐

评论列表()

    联系我们

    联系我们

    0898-88888888

    在线咨询: QQ交谈

    邮箱: email@wangzhan.com

    工作时间:周一至周五,9:00-17:30,节假日休息

    关注微信
    微信扫一扫关注我们

    微信扫一扫关注我们

    关注微博
    返回顶部