有限状态机(Finite - state machine, FSM),又称有限状态自动机,简称状态机,是表示有限个状态以及在这些状态之间的转移和动作等行为的数学模型
有限:表示是有限度的不是无限的
状态:指所拥有的所有状态
举例说明:
假设我们人会做很多个动作,也就是有很多种状态
这些状态包括 站立、走路、跑步、攻击、防守、睡觉等等
我们每天都会在这些状态中切换,而且这些状态虽然多但是是有限的
当达到某种条件时,我们就会在这些状态中进行切换
而且这种切换时随时可能发生的
游戏开发中有很多功能系统都是有限状态机
最典型的状态机系统
- //最简单的状态机实现代码就是基于switch的实现
-
- //假设我们只有一个值来控制当前玩家的状态
- string animName = "idle";
- switch (animName)
- {
- case "idle":
- //待机动作逻辑
- break;
- case "move":
- //移动动作逻辑
- break;
- case "run":
- //跑步动作逻辑
- break;
- case "atk":
- //攻击动作逻辑
- break;
- }
两种方法: