一个用go实现的超容易上手的有限状态机。
它的特点:
为什么不使用looplab/fsm,star挺多的啊。
不是特别喜欢,每次实例化fsm都需要重新传递对应events(虽然我们可以统一封装),我更期望在项目启动时把此项目涉及到不同业务状态机流转注册到fsm,对应:不同业务->[状态]->[事件]->处理事件主体(包含handler、params、hooks、observers等)。
这就是easyfsm的由来。
当你开始进行状态流转时,只需要,
为什么需要区分业务?
因为绝大多数业务的状态值都是从数据库中获取的,比如订单表的订单状态,商品表中的商品状态,有可能值是相同的。
同一个业务同一属性对应状态值表达单一,不同业务下属性状态可能会出现值相同,但所表达的含义是不同的。
整体设计:
简单解释一下:
首先自定义业务、状态、事件。
自定义事件主体,
注册到easyfsm。
开始使用。
完整示例代码如下,
如果想在处理事件函数的前后执行一些hook,或者在事件执行完毕,异步执行一些其他业务,easyfsm定义了这两个接口,
我们可以实现这两个接口,
完整代码:
总结
上面简单介绍了下easyfsm设计以及对应使用姿势。
如果有其他不一样的需求,欢迎大家在issue留言提需求。 https://github.com/wuqinqiang/easyfsm
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。