概述
最近在做一个项目,中间需要一个串口数据传输并且检测有效序列的问题要解决。(是在单片机上做的 msp430f149)
由于以前做过一段时间的FPGA设计,在fpga中,这个检测就是一个序列状态检测机就能搞定。而且速度非常的快,用的是verilog语言,一种硬件描述语言。它和C语言的的工作模型完全不一样的。其实说了这些。我就是想把这种状态机知识迁移到我的单片机上,然后解决我的问题 。
我的初步思路是这样的:
#define IDLE 0
#define STATEA 1
...
int state;while(1)
{
switch (state)
{
case IDLE:if()
{......
}
case STATEA:if()
{.......
}
.......
}
}
使用define把所有的状态宏定义出来,使用switch -case 选择,放入一个while中实现不但的检测。
说了这些,我就把最后自己在单片机430上实现的代码贴出来。大家参考参考:
MCU:MSP430f194
通讯格式:RS232 9600
接收数据报(32字节),包头四字节效验位是:0xAA 0xD0 0x08 0x00;
下面是状态机状态的定义,以及序列检测函数
#include <msp430x14x.h>
#define num1 0x00
#define num2 0x02
#define num3 0x04
#define num4 0x06
#define num5 0x08
/*
检测上传数据开始的位
检测到前五字节正确返回1,否则返回0;
*/
unsigned char check_sta(void)
{
unsigned char state;
unsigned char Temp;
state=num1;
while(1)
{
Temp=get_data();
switch(state)
{
case num1:{
if(Temp==0xAA)
state=num2;
else
break;
}
case num2:{
if(Temp==0xD0)
state=num3;
else
break;;
}
case num3:{
if(Temp==0x08)
state=num4;
else
break;;
}
case num4:{
if(Temp==0x00)
state=num5;
else
break;;
}
case num5:{
if(Temp==0x00)
{
state=num1;
return 1;
}
else
break;;
}
}
}
}
主要是,状态的切换,以及最后循环的退出。代码有的地方写的可能不是很精简,希望指正。
最后
以上就是震动八宝粥为你收集整理的用C语言写一个状态机的全部内容,希望文章能够帮你解决用C语言写一个状态机所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复