⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 -

📁 有限状态机设计与实现源代码.zip
💻
字号:
/*********用过程编程的方法实现FSM程序源代码*******/
#include "iostream.h"
const int MaxStates=3;
const int MaxEvents=3;

const int StateA=0;
const int StateB=1;
const int StateC=2;

const int EventA=0;
const int EventB=1;
const int EventC=2;

int Noop();
int StateAEventA();
int StateAEventB();
int StateBEventA();
int StateBEventC();
int StateCEventA();

int state;

typedef int (*Action)();

Action sm[MaxStates][MaxEvents]={{StateAEventA,StateAEventB,Noop},{StateBEventA,Noop,StateBEventC},{StateCEventA,Noop,Noop}};
int Noop()
{
	cout<<"No Transition"<<endl;
	return state;
};
int StateAEventA()
{
	cout<<"stateA----->stateB"<<endl;
	return StateB;
};
int StateAEventB()
{
	cout<<"stateA----->stateC"<<endl;
	return StateC;
};
int StateBEventA()
{
	cout<<"stateB----->stateC"<<endl;
	return StateC;
};
int StateBEventC()
{
	cout<<"stateB------>stateA"<<endl;
	return StateA;
};
int StateCEventA()
{
	cout<<"stateC------>stateA"<<endl;
	return StateA;
};
void main()
{
	int event;
	state=StateA;
	while(1)
	{
		cout<<"type event:(0-3)"<<endl;
		cin>>event;
		if((event>=0)&&(event<3))
		{
			state=sm[state][event]();
		}
		else
		{
			cout<<"Unknow event"<<endl;
		}
	}
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -