IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 【浅谈状态机】枚举+switch实现C语言状态机、抽象类 公有继承实现C++状态机 -> 正文阅读

[C++知识库]【浅谈状态机】枚举+switch实现C语言状态机、抽象类 公有继承实现C++状态机

1.枚举+switch实现C语言状态机

eg. 求一个已知字符串中有多少个单词。【单词里->单词外~代表有一个单词,num++】

注意:最后一个单词在循环中无法判断(不会由单词里->单词外),需要在退出循环后判断状态是否为INWORD,若为INWORD,则num++。不能盲目++,因为如果字符串以符号结尾,则最后一个单词不会误判,不需要num++。

#include<iostream>
using namespace std;
#include<stdlib.h>
#include<ctype.h>

enum State { BEGIN = 0, INWORD = 1, OUTWORD = 2 };//状态机
int Get_Word_Num(const char* str)//函数功能:获取字符串单词个数
{
	State tag = BEGIN;//定义初始状态BEGIN
	int num = 0;//计数
	for (; *str != '\0'; str++)//循环判断字符串每个字母
	{
		switch (tag)
		{
		case BEGIN:
			if (isalpha(*str)) tag = INWORD;//isalpha()为从type.h中的函数,判断是否为英文字母
			else tag = OUTWORD;//是英文字母则BEGIN->INWORD,否则BEGIN->OUTWORD
			break;
		case INWORD:
			if (!isalpha(*str))//下面两句必须在if块中!
			{
				tag = OUTWORD;//不是英文字母则INWORD->OUTWORD
				num += 1;//且单词里->单词外 num++
			}
			break;
		case OUTWORD:
			if (isalpha(*str)) tag = INWORD;//是英文字母则OUTWORD->INWORD
			break;
		}
	}
	//注意:防止漏掉最后一个单词,退出循环后应判断状态是否为INWORD。若为INWORD,则num++。
	if (tag == INWORD) num+=1;
	return num;
}
int main()
{
	const char* str = { "hello my friend , Long time no see" };
	cout << "该字符串中有" << Get_Word_Num(str) << "个单词!" << endl;//7个
	return 0;
}

2.ctype.h头文件中函数扩展?

3.抽象类、公有继承实现C++状态机

eg. 青蛙变王子(状态转移)。【抽象类 公有继承】

class Creature
{
	class State
	{
	public:
		virtual string response() = 0;//定义纯虚函数->State变为抽象类(供子类继承)
	};
	class Frog :public State //子类继承抽象类~实现其所有纯虚方法
	{
		string response()
		{
			return "Croak...";//croak~呱呱地叫
		}
	};
	class Prince :public State
	{
		string response()
		{
			return "Darling!";
		}
	};

private:
	State* p;//定义成员 基类指针
public:
	Creature()
	{
		cout << "Create Creature" << endl;
		p = new Frog();//用子类对象(类名+())构建基类指针
	}
	void greet()
	{
		string str=p->response();//调用子类各自实现的纯虚函数
		cout << str << endl;
	}
	void kiss()
	{
		delete p;
		p = new Prince();//重新构建Prince类的对象
	}
	virtual ~Creature()//虚析构!!!
	{
		if(p!=nullptr) delete p;//释放new来的空间
		cout << "~Creature" << endl;
	}
};
int main()
{
	Creature cre;
	cre.greet();
	cre.kiss();
	cout << "The little girl kissed frog...Frog->Prince." << endl;
	cre.greet();
	return 0;
}

运行结果如下:

?

?【附加】当然C++的状态机是易于扩展的。此话怎讲?

我们可以在Creature类中再写新的子类去继承父类State,再只需要将kiss函数中delete p;后用新的类构造对象给基类指针赋值即可。greet函数会调用相应子类的reponse函数。

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-10-08 20:22:11  更:2022-10-08 20:23:57 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/19 2:26:19-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码