C函数指针状态机实现
C函数指针状态机实现
有限状态机(finite state machine)简称FSM,表示有限个状态及在这些状态之间的转移和动作等行为的数学模型,在计算机领域有着广泛的应用。FSM是一种逻辑单元内部的一种高效编程方法,在服务器编程中,服务器可以根据不同状态或者消息类型进行相应的处理逻辑,使得程序逻辑清晰易懂。
#include <stdio.h> //函数指针实现FSM enum year_state { SPRING = , SUMMER, AUTUMN, WINTER }; enum year_event { EVENT1 = , EVENT2, EVENT3, EVENT4 }; typedef struct FsmTable_s { int event; // 事件 int CurState; // 当前状态 void (*eventActFun)(); //函数指针 int nextState; // 下一个状态 } FsmTable_t; void spring_thing() { printf("this is spring\n"); } void summer_thing() { printf("this is summer\n"); } void autumn_thing() { printf("this is autumn\n"); } void winter_thing() { printf("this is winter\n"); } FsmTable_t year_table[] = { //{到来的事件,当前的状态,将要要执行的函数,下一个状态} { EVENT1, SPRING, summer_thing, SUMMER }, { EVENT2, SUMMER, autumn_thing, AUTUMN }, { EVENT3, AUTUMN, winter_thing, WINTER }, { EVENT4, WINTER, spring_thing, SPRING }, //add your codes here }; typedef struct FSM_s { int curState;//当前状态 FsmTable_t * pFsmTable;//状态表 int size;//表的项数 } FSM_t; /*状态机注册,给它一个状态表*/ void FSM_Regist(FSM_t *pFSM, FsmTable_t *pFsmTable) { pFSM->pFsmTable = pFsmTable; } /*状态迁移*/ void FSM_StateTransfer(FSM_t* pFsm, int state) { pFsm->curState = state; } /*事件处理*/ void FSM_EventHandle(FSM_t* pFsm, int event) { FsmTable_t* pActTable = pFsm->pFsmTable; void (*eventActFun)() = NULL; //函数指针初始化为空 int NextState; int CurState = pFsm->curState; int g_max_num = pFsm->size; ; //标识是否满足条件 int i; ; i < g_max_num; i++) { if (event == pActTable[i].event && CurState == pActTable[i].CurState) { flag = ; eventActFun = pActTable[i].eventActFun; NextState = pActTable[i].nextState; break; } } if (flag) { if (eventActFun) { eventActFun(); } FSM_StateTransfer(pFsm, NextState); } else { printf("There is no match\n"); } } int main() { FSM_t year_fsm; FSM_Regist(&year_fsm, year_table); year_fsm.curState = SPRING; year_fsm.size = sizeof(year_table)/sizeof(FsmTable_t); printf("\n-------1--init spring------\n"); printf("state:%d\n",year_fsm.curState); printf("\n-------2--spring->summer------\n"); FSM_EventHandle(&year_fsm,EVENT1); printf("state:%d\n",year_fsm.curState); printf("\n-------3--summer->autumn------\n"); FSM_EventHandle(&year_fsm,EVENT2); printf("state:%d\n",year_fsm.curState); printf("\n-------4--autumn->winter------\n"); FSM_EventHandle(&year_fsm,EVENT3); printf("state:%d\n",year_fsm.curState); printf("\n-------5--winter->spring------\n"); FSM_EventHandle(&year_fsm,EVENT4); printf("state:%d\n",year_fsm.curState); printf("\n-------6--receive EVENT2 not EVENT1------\n"); FSM_EventHandle(&year_fsm,EVENT2); printf("state:%d\n",year_fsm.curState); }
C函数指针状态机实现的更多相关文章
- C/C++用状态转移表联合函数指针数组实现状态机FSM
状态机在project中使用很的频繁,有例如以下常见的三种实现方法: 1. switch-case 实现.适合简单的状态机. 2. 二维状态表state-event实现.逻辑清晰.可是矩阵通常比較稀疏 ...
- C++虚函数和函数指针一起使用
C++虚函数和函数指针一起使用,写起来有点麻烦. 下面贴出一份示例代码,可作参考.(需要支持C++11编译) #include <stdio.h> #include <list> ...
- 为什么 C++ 中成员函数指针是 16 字节?
当我们讨论指针时,通常假设它是一种可以用 void * 指针来表示的东西,在 x86_64 平台下是 8 个字节大小.例如,下面是来自 维基百科中关于 x86_64 的文章 的摘录: Pushes a ...
- C++函数指针总结
学习c++的过程中,指针是难点,熟悉了指针之后,还有一个让人很蛋疼的难点,那就是函数指针了.本博文详细介绍一下常见的各种坑爹的函数指针. 至于指针的详细学习,推荐这篇博文C++指针详解 与数据一样,函 ...
- C与指针(结构体指针,函数指针,数组指针,指针数组)定义与使用
类型 普通指针 指针数组(非指针类型) 数组指针 结构体指针 函数指针 二重指针 定义方式 int *p; int *p[5]; int (*p)[5]; int a[3][5]; struct{.. ...
- 结构体内嵌函数指针实现C语言面向对象
结构体内嵌函数指针 #include<stdio.h> void say(int age) { printf("我%d岁了\n",age); } struct stud ...
- 用typedef定义函数指针的问题
在学习windows API的时候,遇到下面这段代码 以前见过的typedef的用法都是给一个数据类型取一个别名 typedef oldTypeName newTypeName 这种给数据类型 ...
- 你必须知道的指针基础-7.void指针与函数指针
一.不能动的“地址”—void指针 1.1 void指针初探 void *表示一个“不知道类型”的指针,也就不知道从这个指针地址开始多少字节为一个数据.和用int表示指针异曲同工,只是更明确是“指针” ...
- objective-c中的@selector()和 c /c++的函数指针
先看tomcat里用到的代码: //然后开始动画 //把图片放到animationImages,接受数组参数 self.tom.animationImages = arrayImage; //设置时间 ...
随机推荐
- idea使用技巧总结
1.idea代码自动补全 https://jingyan.baidu.com/article/36d6ed1f62e9821bcf4883af.html 2.优化_生成main方法_sysout方法 ...
- ssm下的CURD
https://github.com/MenghuiLiu/ssm-curd 以后有更新.... 照着前辈的足迹向前撸
- STL map 详细用法
Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个称为该关键字的值)的数据 处理能力. 需要的库 #include <map> ...
- js异步解决方法
在浏览器端,耗时很长的操作都应该异步执行,避免浏览器失去响应,最好的例子就是Ajax操作.在服务器端,"异步模式"甚至是唯一的模式,因为执行环境是单线程的,如果允许同步执行所有ht ...
- Django settings.py 配置文件详解
settings.py 配置文件 import os BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) #引 ...
- Python机器学习·微教程
Python目前是机器学习领域增长最快速的编程语言之一. 该教程共分为11小节.在这个教程里,你将学会: 如何处理数据集,并构建精确的预测模型 使用Python完成真实的机器学习项目 这是一个非常简洁 ...
- 一次简单的SQL手工注入
1. 首先要了解SQL注入的原理: SQL Injection:就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令. 具体来说,它是利 ...
- Linux curl 表单登录或提交与cookie使用
本文主要讲解通过curl 实现表单提交登录.单独的表单提交与表单登录都差不多,因此就不单独说了. 说明:针对curl表单提交实现登录,不是所有网站都适用,原因是有些网站后台做了限制或有其他校验.我们不 ...
- CSS:抗锯齿 font-smoothing
本文引自:http://www.cnblogs.com/sunshq/p/4595673.html -webkit-font-smoothing 这个属性可以使页面上的字体抗锯齿,使用后字体看起来会更 ...
- LK的NOIP膜拟赛
T1 Learn to 签到 [题目描述] 希希最喜欢二进制了.希希最喜欢的运算是\(\wedge\). 希希还喜欢很多\(01\)序列.这些序列一共有\(n\)个,每个的长度为\(m\). 希希有一 ...