- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
状态机的两种写法
有限状态机FSM思想广泛应用于硬件控制电路设计,也是软件上常用的一种处理方法(软件上称为FMM--有限消息机)。它把复杂的控制逻辑分解成有限个稳定状态,在每个状态上判断事件,变连续处理为离散数字处理,符合计算机的工作特点。同时,因为有限状态机具有有限个状态,所以可以在实际的工程上实现。但这并不意味着其只能进行有限次的处理,相反,有限状态机是闭环系统,有限无穷,可以用有限的状态,处理无穷的事务。
有限状态机的工作原理如图1所示,发生事件(event)后,根据当前状态(cur_state),决定执行的动作
(action),并设置下一个状态号(nxt_state)。
| | 执行动作action
发生事件event |cur_state|
| | 设置下一状态号nxt_state
当前状态
图1有限状态机工作原理
e0/a0
-----
| |
------------------
e0/a0| | S0 |-----
| - |e1/a1
| |e2/a2 V
| S2 |----------| S1 |
e2/a2
图2一个有限状态机实例
当前状态 s0 s1 s2 |事件
a0/s0 -- a0/s0 |e0
a1/s1 -- -- |e1
a2/s2 a2/s2 -- |e2
表1图2状态机实例的二维表格表示(动作/下一状态)图2为一个状态机实例的状态转移图,它的含义是:
在s0状态,如果发生e0事件,那么就执行a0动作,并保持状态不变;如果发生e1事件,那么就执行a1动作,并将状态转移到s1态;
如果发生e2事件,那么就执行a2动作,并将状态转移到s2态;
在s1状态,如果发生e2事件,那么就执行a2动作,并将状态转移到s2态;在s2状态,如果发生e0事件,那么就执行a0动作,并将状态转移到s0态;
有限状态机不仅能够用状态转移图表示,还可以用二维的表格代表。一般将当前状态号写在横行上,将事件写在纵列上,如表1所示。其中“--”表示空(不执行动作,也不进行状态转移),“an/sn”表示执行动作an,同时将下一状态设置为sn。表1和图2表示的含义是完全相同的。
观察表1可知,状态机可以用两种方法实现:竖着写(在状态中判断事件)和横着写(在事件中判断状态)。这两种实现在本质上是完全等效的,但在实际操作中,效果却截然不同。
==================================
竖着写(在状态中判断事件)C代码片段
==================================
cur_state=nxt_state;
switch(cur_state){ //在当前状态中判断事件cases0: //在s0状态
if(e0_event){ //如果发生e0事件,那么就执行a0动作,并保持状态不变;
执行a0动作;
//nxt_state=s0; //因为状态号是自身,所以可以删除此句
,以提高运行速度。
}
elseif(e1_event){ //如果发生e1事件,那么就执行a1动作,并将状态转移到s1态;
执行a1动作;nxt_state=s1;
}
elseif(e2_event){ //如果发生e2事件,那么就执行a2动作,并将状态转移到s2态;
执行a2动作;nxt_state=s2;
}
break;
cases1: //在s1状态
if(e2_event){ //如果发生e2事件,那么就执行a2动作,并将状态转移到s2态;
执行a2动作;nxt_state=s2;
}
break;
cases2: //在s2状态
if(e0_event){ //如果发生e0事件,那么就执行a0动作,并将状态转移到s0态;
执行a0动作;nxt_state=s0;
}
}
==================================
横着写(在事件中判断状态)C代码片段
==================================
//e0事件发生时,执行的函数
voide0_event_function(int*nxt_state)
{
intcur_state;
cur_state=*nxt_state;switch(cur_state){
cases0: //观察表1,在e0事件发生时,s1处为空
cases2:
执行a0动作;
*nxt_state=
您可能关注的文档
最近下载
- 2025年中国电子信息产业集团有限公司招聘笔试参考题库含答案解析.pdf
- 《电磁兼容+试验和测量技术+第11部分:对每相输入电流小于或等于16+a设备的电压暂降、短时中断和电压变化抗扰度试验gbt 17626.11-2023》详细解读 .pdf
- 合肥市申领居住证的申请.docx
- 高考二轮复习资料专题二2.2 动能定理和动量定理(二).doc VIP
- 2024年重庆市中考地理试题卷(含官方答案及解析).docx
- 湖北省恩施市第一中学2025届高三最后一模数学试题含解析.doc
- 2024年河南经贸职业学院单招职业技能测试题库及答案解析.pdf VIP
- 2022年版语文课程标准新课标考试题库及答案6.pdf
- 试卷讲评教学反思(8篇).pdf VIP
- 钢结构施工技术交底..doc VIP
文档评论(0)