当前位置: 首页 > article >正文

C语言状态机实现的三种方法与实践

状态机实现的三种经典方法及其工程实践1. 状态机基础概念1.1 状态机核心要素状态机实现包含三个基本要素状态(State): 系统所处的当前状况事件(Event): 触发状态转移的外部输入响应(Response): 状态转移时执行的动作这三个要素可以转化为三个基本问题发生了什么事件系统当前处于什么状态在该状态下发生该事件系统应该做什么1.2 状态机分类在嵌入式系统中常见的状态机类型包括有限状态机(FSM): 系统在任何时刻只处于一个确定状态层次状态机(HSM): 包含父子关系的多级状态机结构并行状态机: 多个独立状态机同时运行2. C语言实现状态机的三种方法2.1 switch-case法2.1.1 基本实现原理switch-case法通过嵌套的switch语句实现状态机switch(StateVal) { case S0: switch(EvntID) { case E1: action_S0_E1(); /* S0状态下E1事件的响应 */ StateVal new_state_value; /* 状态迁移 */ break; case E2: action_S0_E2(); /* S0状态下E2事件的响应 */ StateVal new_state_value; break; /* 其他事件处理 */ default: break; } break; case S1: /* 类似处理 */ break; /* 其他状态处理 */ default: break; }2.1.2 实现变体switch-case法有两种嵌套方式状态嵌套事件外层switch处理状态内层处理事件事件嵌套状态外层switch处理事件内层处理状态2.1.3 性能优化建议将高频状态和实时性要求高的事件放在switch语句靠前位置对于特定状态下无意义的事件可以省略对应case分支避免简单的顺序排列应根据实际运行频率优化顺序2.2 表格驱动法2.2.1 基本数据结构表格驱动法使用二维表格组织状态和事件关系struct fsm_node { void (*fpAction)(void *pEvnt); /* 动作函数指针 */ INT8U u8NxtStat; /* 下一状态 */ };2.2.2 实现原理纵轴表示事件横轴表示状态交点[Sn, Em]表示系统在Sn状态下对Em事件的响应响应包含动作函数和状态迁移2.2.3 框架代码示例extern struct fsm_node g_arFsmDrvTbl[][]; /* 状态机驱动表格 */ INT8U u8CurStat 0; /* 当前状态 */ INT8U u8EvntTyp 0; /* 事件类型 */ void *pEvnt NULL; /* 事件数据指针 */ u8CurStat get_cur_state(); /* 获取当前状态 */ u8EvntTyp get_cur_evnt_typ(); /* 获取事件类型 */ pEvnt (void*)get_cur_evnt_ptr(); /* 获取事件数据 */ struct fsm_node stNodeTmp g_arFsmDrvTbl[u8CurStat][u8EvntTyp]; stNodeTmp.fpAction(pEvnt); /* 执行动作 */ set_cur_state(stNodeTmp.u8NxtStat);/* 状态迁移 */2.2.4 优缺点分析优点接口统一调用规范查找效率高数组寻址框架代码可重用缺点可读性较差需配合状态转换图扩展性有限添加状态/事件需修改表格不支持扩展状态机(ESM)2.3 函数指针法2.3.1 基本思想函数指针法将状态直接表示为函数地址通过函数返回值决定下一状态。2.3.2 数据结构struct fsm_node { INT8U (*fpAction)(void *pEvnt); /* 返回下一状态的函数指针 */ INT8U u8StatChk; /* 状态校验值 */ };2.3.3 实现示例INT8U action_S0(void *pEvnt) { INT8U u8NxtStat 0; INT8U u8EvntTyp get_evnt_typ(pEvnt); switch(u8EvntTyp) { case E1: action_S0_E1(); /* 事件E1的动作响应 */ u8NxtStat new_state_value; break; /* 其他事件处理 */ default: break; } return u8NxtStat; /* 返回新状态 */ }2.3.4 安全机制状态校验字段(u8StatChk)防止非法状态可通过枚举类型限定状态值范围3. 高级状态机技术3.1 压缩表格驱动法3.1.1 改进原理将二维表格压缩为一维数组动作函数返回下一状态而非固定迁移解决了ESM支持问题3.1.2 实现示例struct fsm_node { INT8U (*fpAction)(void *pEvnt); /* 事件处理函数指针 */ INT8U u8StatChk; /* 状态校验 */ }; u8CurStat get_cur_state(); struct fsm_node stNodeTmp g_arFsmDrvTbl[u8CurStat]; if(stNodeTmp.u8StatChk u8CurStat) { u8CurStat stNodeTmp.fpAction(pEvnt); /* 事件处理并获取新状态 */ set_cur_state(u8CurStat); /* 状态迁移 */ } else { state_crash(u8CurStat); /* 非法状态处理 */ }3.2 扩展状态机(ESM)ESM特点响应事件前先判断条件根据条件选择不同动作和状态迁移迁移目标不唯一更具灵活性3.3 层次状态机(HSM)HSM特点多个状态机形成层次结构父子状态机之间存在上下级关系比FSM更强大的建模能力4. 状态机设计实践建议4.1 方法选择指南方法适用场景复杂度灵活性性能switch-case简单状态机状态/事件数量少低高中表格驱动中等规模需要统一框架中中高函数指针复杂状态机需要最大灵活性高高高压缩表格驱动需要ESM支持的中等规模状态机中高高高4.2 设计流程问题分析明确系统需要建模的行为状态划分识别系统可能处于的各种状态事件识别确定触发状态转移的外部事件转换定义为每个状态-事件对定义响应和迁移优化验证检查状态机的完备性和一致性4.3 性能优化技巧对于高频状态/事件使用查表法(表格驱动)提高效率合理组织状态/事件顺序将高频项前置使用const修饰驱动表格节省RAM空间考虑使用枚举类型限定状态/事件范围4.4 可维护性建议保持状态转换图与代码同步更新为每个状态和事件添加详细注释使用有意义的命名规范实现状态校验机制提高鲁棒性5. 状态机在嵌入式系统中的典型应用5.1 通信协议处理串口通信状态机网络协议栈实现总线通信管理5.2 用户界面控制按键输入处理菜单系统导航显示状态管理5.3 设备工作模式管理电源状态管理传感器采集流程执行机构控制通过合理应用状态机技术可以显著提高嵌入式系统的结构清晰度、可维护性和可靠性。三种实现方法各有特点工程师应根据项目具体需求选择最适合的方案。

相关文章:

C语言状态机实现的三种方法与实践

状态机实现的三种经典方法及其工程实践1. 状态机基础概念1.1 状态机核心要素状态机实现包含三个基本要素:状态(State): 系统所处的当前状况事件(Event): 触发状态转移的外部输入响应(Response): 状态转移时执行的动作这三个要素可以转化为三个基本问题:发…...

嵌入式开发中的务实与专注:工程师的技术哲学

嵌入式工程师的务实思考:技术开发中的本分与专注1. 技术开发中的浮躁现象观察1.1 行业现状分析当前技术领域存在明显的浮躁倾向,表现为过度营销、急功近利和忽视基础价值。这种现象在消费电子领域尤为突出,各种"智能"、"革命性…...

SDMatte在Vue前端项目中的应用:打造交互式在线抠图工具

SDMatte在Vue前端项目中的应用:打造交互式在线抠图工具 1. 引言:为什么选择SDMatte做在线抠图? 最近在开发一个需要图片处理功能的Vue项目时,我发现很多用户都有快速抠图的需求。传统的Photoshop操作复杂,而市面上的…...

C++Qt中异常处理try-catch的实战应用与优化策略

1. 为什么我们需要异常处理? 在C和Qt开发中,程序运行时难免会遇到各种意外情况。想象一下,你正在开发一个文件管理器应用,用户突然删除了正在编辑的文件;或者开发一个网络应用时,服务器突然断开连接。这些情…...

300W数据集深度解析:从数据构成到实际应用场景

1. 300W数据集全景解析:你的第一本人脸对齐百科全书 第一次接触300W数据集时,我和所有初学者一样被各种缩写搞晕——AFW、HELEN、IBUG这些字母组合到底代表什么?后来才发现,这就像不同产地的咖啡豆,虽然都叫"咖啡…...

STM32 ADC电压测量避坑指南:为什么你的读数总是不准?

STM32 ADC电压测量避坑指南:为什么你的读数总是不准? 在嵌入式开发中,精确的电压测量往往是系统可靠性的关键。许多STM32开发者在使用内置ADC时都遇到过这样的困扰:明明电路连接正确,代码逻辑也没问题,但测…...

别再到处找了!这个宝藏IT电子书网站,Python/Java/Go等上万本技术书免费下

技术人专属电子书宝库:高效获取与利用指南 在技术学习与职业发展的道路上,优质的电子书资源如同黑夜中的明灯。对于Python、Java、Go等主流技术的研习者而言,找到一本结构清晰、案例丰富的电子书往往能让学习事半功倍。然而,互联网…...

思源宋体TTF:企业级开源中文字体的技术解析与场景落地指南

思源宋体TTF:企业级开源中文字体的技术解析与场景落地指南 【免费下载链接】source-han-serif-ttf Source Han Serif TTF 项目地址: https://gitcode.com/gh_mirrors/so/source-han-serif-ttf 一、价值定位:开源字体的战略选择 1.1 字体选型的商…...

s2-proGPU算力利用:通过量化压缩将模型体积减少60%实测报告

s2-pro GPU算力利用:通过量化压缩将模型体积减少60%实测报告 1. 专业语音合成工具s2-pro简介 s2-pro是Fish Audio开源的专业级语音合成模型镜像,它能够将文本转换为自然流畅的语音。这个工具最吸引人的特点是支持通过参考音频来复用特定音色&#xff0…...

GTE+SeqGPT构建RAG系统:从理论到实践

GTESeqGPT构建RAG系统:从理论到实践 用最接地气的方式,带你从零搭建一个真正能用的智能问答系统 1. 开篇:为什么需要RAG系统? 你有没有遇到过这种情况:问AI一个问题,它回答得头头是道,但仔细一…...

别再瞎选了!Vivado 2023.2 综合策略实战:从‘跑得快’到‘布得通’的保姆级避坑指南

Vivado 2023.2综合策略深度解析:从理论到实战的智能选择方法论 在FPGA开发领域,综合阶段的质量往往决定了整个项目的成败。面对Vivado提供的十余种综合策略,许多工程师陷入了"选择困难症"——要么盲目跟随他人经验,要么…...

WaveTerm终极指南:如何用开源AI终端提升10倍工作效率

WaveTerm终极指南:如何用开源AI终端提升10倍工作效率 【免费下载链接】waveterm An open-source, cross-platform terminal for seamless workflows 项目地址: https://gitcode.com/GitHub_Trending/wa/waveterm 你是否厌倦了在多个终端窗口、代码编辑器、网…...

企业级RAG项目避坑指南(非常详细),8大架构陷阱全解析,收藏这一篇就够了!

过去一年,越来越多企业开始建设AI 知识库系统。 几乎所有方案都会提到一个技术:Retrieval-Augmented Generation(RAG)。 RAG 的理念很简单: 让大模型先检索企业数据,再生成答案。 理论上,这可…...

收藏!小白程序员必学:手把手带你入门AI大模型工作流,从零构建智能体

本文深入浅出地介绍了AI大模型工作流(Agentic Workflow)的核心概念与实际应用,通过解析“反思模式”、“工具使用模式”、“推理-行动模式”、“规划模式”及“多智能体模式”,阐述了AI如何像人类一样分步完成任务。文章强调AI不再…...

vLLM部署GLM-4-9B-Chat-1M:Ubuntu系统优化配置

vLLM部署GLM-4-9B-Chat-1M:Ubuntu系统优化配置 1. 引言 如果你正在尝试在Ubuntu系统上部署GLM-4-9B-Chat-1M这个支持百万级上下文的大模型,可能会遇到显存不足、推理速度慢或者输出异常等问题。这其实很正常,毕竟要让一个90亿参数的模型流畅…...

突破3D打印瓶颈:PrusaSlicer的5个效率倍增法则

突破3D打印瓶颈:PrusaSlicer的5个效率倍增法则 【免费下载链接】PrusaSlicer G-code generator for 3D printers (RepRap, Makerbot, Ultimaker etc.) 项目地址: https://gitcode.com/gh_mirrors/pr/PrusaSlicer 传统3D打印流程中,切片软件往往成…...

打卡信奥刷题(3005)用C++实现信奥题 P6221 [COCI 2019/2020 #6] Trener

P6221 [COCI 2019/2020 #6] Trener 题目背景 题目翻译来自 LOJ3270。 题目描述 译自 COCI 2019/2020 Contest #6 T5. Trener 我们已经知道了学生们喜欢睡觉。Patrik 是这一记录的保持者。在最后一个梦中,他发现自己成为了他最喜欢的球队的队长。 为了参加一场…...

ClearerVoice-Studio在网络安全中的应用:语音加密与认证

ClearerVoice-Studio在网络安全中的应用:语音加密与认证 1. 引言 想象一下这样的场景:你正在通过视频会议讨论重要的商业机密,或者通过语音助手处理银行转账,突然发现有人窃听了你们的对话。这种安全威胁在数字化时代变得越来越…...

停用词表避坑指南:为什么你的中文分词效果总不理想?

停用词表避坑指南:为什么你的中文分词效果总不理想? 在自然语言处理的实际应用中,许多初学者常会遇到一个令人困惑的现象:明明采用了先进的分词算法,但处理结果却总是不尽如人意。问题的根源往往不在于模型本身&#x…...

《干货满满!提示工程架构师的提示系统技术管理指南》

干货满满!提示工程架构师的提示系统技术管理指南 一、引言:从“散养prompt”到“系统工程”的必经之路 1. 一个让所有提示工程师头疼的场景 你是否遇到过这样的情况? 客服团队说:“昨天的订单查询提示还能用,今天怎么突然回复混乱了?” 开发同学问:“这个提示是哪个版…...

打卡信奥刷题(3004)用C++实现信奥题 P6202 [USACO07CHN] Summing Sums G

P6202 [USACO07CHN] Summing Sums G 题目描述 NNN 头奶牛(1≤N≤51041 \leq N \leq 5 \times 10^41≤N≤5104)刚刚学习了不少密码学知识,终于,她们创造出了属于奶牛的加密方法,由于她们经验不足,她们的加密…...

轻量级嵌入式传感器抽象库:HC-SR04与LDR驱动设计

1. Sensors库概述:面向嵌入式系统的轻量级传感器抽象层Sensors库是一个专为资源受限嵌入式平台设计的轻量级C语言传感器驱动抽象库,核心聚焦于两类典型模拟/数字混合型传感器:HC-SR04超声波测距模块与LDR(Light Dependent Resisto…...

Gemma-3 Pixel Studio部署教程:Streamlit一键镜像免配置,BF16+Flash Attention 2极速启动

Gemma-3 Pixel Studio部署教程:Streamlit一键镜像免配置,BF16Flash Attention 2极速启动 1. 项目概述 Gemma-3 Pixel Studio是基于Google最新开源的Gemma-3-12b-it模型构建的高性能多模态对话终端。它不仅具备强大的文本理解和生成能力,还集…...

NifSkope:开源3D模型编辑工具如何重塑游戏资产工作流

NifSkope:开源3D模型编辑工具如何重塑游戏资产工作流 【免费下载链接】nifskope A git repository for nifskope. 项目地址: https://gitcode.com/gh_mirrors/ni/nifskope 在游戏开发与模组制作领域,处理NIF格式的3D模型文件一直是个技术挑战。Ni…...

主动对标无菌药品生产标准!这家第三方检测机构如何落地“药品级“污染控制策略(CCS)

作为一家细胞库检定的第三方检测机构,义翘神州主动对标欧盟GMP附录1及国内无菌药品生产要求,构建了一套系统化的污染控制策略(CCS)。今天,就让我们拆解这份“高标准、严要求”的CCS管理体系,看看第三方检测…...

ButtinoRAK:RAK3172深度睡眠与硬复位按键控制库

1. 项目概述ButtinoRAK 是一个面向 RAK3172 LoRaWAN 模块的轻量级、强约定(opinionated)Arduino 库,专为低功耗嵌入式场景设计。其核心目标并非提供通用按钮抽象层,而是将物理按键行为直接映射为系统级电源状态机——通过预设的、…...

FigmaCN 技术架构深度解析:现代浏览器扩展本地化方案的设计与实现

FigmaCN 技术架构深度解析:现代浏览器扩展本地化方案的设计与实现 【免费下载链接】figmaCN 中文 Figma 插件,设计师人工翻译校验 项目地址: https://gitcode.com/gh_mirrors/fi/figmaCN FigmaCN 作为一款面向中文设计师的 Figma 界面本地化工具&…...

LLM·minimind-预训练

文章目录预训练初始化模型和分词器初始化配置文件 AutoConfig从配置文件初始化 AutoModel加载 AutoTokenizer预训练数据集加载数据集DataDictDataset数据预处理数据预先处理函数1.数据集编码为tokens2.数据集分块,获得特定长度的input_ids和labels训练器TrainingArg…...

GitHub中文界面工具:突破语言壁垒的开源解决方案

GitHub中文界面工具:突破语言壁垒的开源解决方案 【免费下载链接】github-chinese GitHub 汉化插件,GitHub 中文化界面。 (GitHub Translation To Chinese) 项目地址: https://gitcode.com/gh_mirrors/gi/github-chinese GitHub作为全球领先的代码…...

量子走私系统架构与检测规避原理的技术解构

一、量子物流系统的非法改造框架量子纠缠通信层量子信道构建:利用纠缠光子对建立跨国信道,通过BB84协议实现密钥分发。发送方(毒枭)与接收方(境外据点)共享量子态,海关拦截将导致量子态坍缩&…...