工作流的基本功能

工作流的书现在不少了,规范也不少了,开源项目更不少了,学起来要好久了。但是到底一个工作流系统要有什么用呢?记得看过一篇文章,还列了100多点功能,看着头大。能不能简单的说明,工作流是做什么的?用了一个工作流后,一个系统应该有什么样的效果呢?

在我这个土包子看来,一个好的工作流有这三个功能:

第一个最大的功能是流程控制。简单的说,就是消灭if-else和switch-case语句。一个使用工作流的系统,在页面和业务类都不应该有太多的if-else和switch-case。这两者都是控制业务流程流转的,而这项工作,是工作流的天职。所以如果系统用了工作流,还是有大量的这种语句,那么这个系统就是失败而毫无意义的。其实二和三都是这个功能的子功能。

第二个功能是状态控制,简单的说,就是消灭对业务表的getStatus和setStatus,无论pestiNet比FSM的理论先进多少,状态控制始终也是工作流最大好处之一。伴随着流程的流转,在某个点状态都是定好了,我们无须操心,直接打印出来就OK了,这个是对于有一个主业务数据,并关心其状态的业务模型,这个是重中之重。就好像无论你吹嘘社会主义比资本主义先进多少倍,保证人民的温饱才是最重要的。如果我用了工作流,还整天要去关心和update一个唯一主业务表的状态,那无疑是悲哀的。当然,多业务数据状态是另外一回事。

第三个功能是角色控制。简单的说,就是消灭if (user == ***) || (roles == ***))这种语句。角色或者用户所能获得的任务,所能进行的操作,都是在工作流引擎里面返回出来的时候,都已经做了过滤判断了,上层代码,无须关心。

为了有效的完成这三个功能,一个工作流引擎,无论基于那种理论进行内部流转,都还应该提供足够的支持,能够灵活的插入业务判断和执行点,根据业务,进行原子业务逻辑判断和操作,角色处理。

这三个功能的实现,是一个工作流系统成功应用的标准,如果一个工作流引擎,不能满足这样的需求,那么无论它的核心理论是多么先进的,那么它也始终是学院派的一个玩具而已,而不是一个对于企业应用系统真正有用的产品。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值