day18
- 有限状态机解析http协议
-
什么是有限状态机
-
- 有限状态机,(英语:Finite-state machine, FSM),又称有限状态自动机,简称状态机,是表示有限个状态以及在这些状态之间的转移和动作等行为的数学模型。当逻辑里面有大量判断需要转换状态时,有限状态机就有用处了,本质上其是用查表法来把处理逻辑独立到表中,从而可以用通用的代码去处理任意复杂的状态转换
-
-
- 有限状态机的编程并不是一个困难事。更重要的是要理清楚状态转移的逻辑和方式,代码是很好写的。
-
-
- 枚举enum的使用方法
如果一个变量的取值只有几种有限的可能性,我们可以将其定义为枚举类型:如下代码:
enum enumType
{ MONDAY, TUESDAY, WENESDAY, THURSDAY, FRIDAY, SATURDAY, SUNDAY };
// 匿明枚举
enum
{ MONDAY, TUESDAY, WENESDAY, THURSDAY, FRIDAY, SATURDAY, SUNDAY };
枚举类型具有以下几个特点:
-
不指定具体的数据类型。默认是数值,像上面的代码中,按照枚举中变量的顺序,从0开始依次给每一个赋值
-
- 也可以显式的给枚举中的变量赋值,但是必须是整数
-
枚举类型只有赋值运算,没有算术运算
-
只能将枚举变量赋值给非枚举变量,例如
int today = MONDAY;
是合法的,但是反过来就是错误的 -
枚举的作用域是全局的,在不同的枚举中不能使用相同名字的变量
-
- C++11 中出现的enum class 枚举类让变量拥有了自己的作用域,同时可以指定枚举变量的数据类型,是一种更加安全的使用方式。
- strpbrk函数
char *strpbrk(const char *s, const char *accept);
函数功能:在 字符串 s 中 查找 第一个出现 字符串 accept 中任一字符的 位置
返回值:返回查找到的位置