工作流_阐述_工作流模式(C1)

2024-04-09 17:38
文章标签 模式 工作 阐述 c1

本文主要是介绍工作流_阐述_工作流模式(C1),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

工作流模式指在工作流过程模型中反复出现的过程基本构造,是衡量工作流建模语言在控制流方面的表达能力和适用性的重要标准。工作流模式经过发展和演变,从最初的20种发展到目前的126种,涉及的范畴从单纯的控制流模式,扩展到基于资源模式、基于数据模式:
[list]
[*] 基于控制流模式 43种(早期是经典的20种,后期扩展到43种)
[*] 基于资源模式 43种
[*] 基于数据模式 40种
[/list]
详细内容可以在工作流模式网站了解:http://www.workflowpatterns.com/patterns/control/index.php 。

网上有部分资料把经典工作流是解释成21种,包括查维基百科也是按照21种阐述的,通过两者的比对,多一种“M中的N模式(N-out-of-M Join)”,其他完全一样,而该模式存在于在43种模式之中。在查阅相关文献,包括一些期刊论文以及工作流模式网站的原始文档出处,在本文说经典工作流模式特指基于控制流模式的20种工作流模式。


术语说明:
[list]
[*] 流程(Process):是由活动(Activity)和子流程(Subflow Activity)按照一定的顺序结构结合而成。
[*] 变迁(transition): 或者称转移,用于连接活动与活动或者活动与子流程之间的有向弧。
[/list]

转移按照XPDL的语意是分为无条件转移和条件转移。但在本工作流引擎实现中,条件判断全部在路由活动中实现,变迁仅仅指明活动之间的连接。可以根据用户的需要,扩展路由活动的种类,从而达到条件表达功能的增加,如果结合规则引擎的条件判断,功能将极大的提升。

活动又可以分为四种(当然,子流程也可以认为是活动的一种):
[list]
[*] 人工活动(activity without implementation):不执行应用或者动作的活动。
[*] 自动活动(tool activity):执行应用或者动作的活动。
[*] 路由活动(route actibity):只用于判断选择路径。
[*] 块活动(block activity):由多个活动(以上三种活动)组成活动。
[/list]


先阐述控制工作流模式:
[size=large][color=red]1、控制流模式经典排列[/color][/size][table]
|[b][size=x-large][color=blue]基本工作流模式[/color][/size] [/b]|
|1. Sequence,顺序|
|2. Parallel Split,并发分支|
|3. Synchronization,同步合并|
|4. Exclusive Choice,异或分支|
|5. Simple Merge,异或合并|
|[b][size=x-large][color=blue]高级分支、同步模式[/color][/size] [/b]|
|6. Multi-Choice,多路选择|
|7. Structured Synchronizing Merge,多路选择、OR分支的合并|
|8. Multi-Merge,多路合并|
|9. Structured Discriminator,结构鉴别|
|[b][size=x-large][color=blue]循环模式[/color][/size] [/b]|
|10. Arbitrary Cycles,强制循环|
|[b][size=x-large][color=blue]终止模式[/color][/size] [/b]|
|11. Implicit Termination,隐式终止|
|[b][size=x-large][color=blue]多实例模式[/color][/size] [/b]|
|12. Multiple Instances without Synchronization,异步多实例|
|13. Multiple Instances with a Priori Design-Time Knowledge,设计期确定多实例|
|14. Multiple Instances with a Priori Run-Time Knowledge,运行时确定同步多实例|
|15. Multiple Instances without a Priori Run-Time Knowledge,运行时非确定多实例|
|[b][size=x-large][color=blue]状态模式[/color][/size] [/b]|
|16. Deferred Choice,延迟选择|
|17. Interleaved Parallel Routing,乱序选择模式|
|18. Milestone,里程碑|
|[b][size=x-large][color=blue]取消模式[/color][/size] [/b]|
|19. Cancel Activity,取消活动|
|20. Cancel Case,取消流程|
|[b][size=x-large][color=blue]扩展模式[/color][/size] [/b]|
|21. Structured Loop,结构化循环|
|22. Recursion,递归|
|23. Transient Trigger,临时触发器|
|24. Persistent Trigger,持续触发器|
|25. Cancel Region,取消范围|
|26. Cancel Multiple Instance Activity,多实例的取消|
|27. Complete Multiple Instance Activity,多实例的手工完成|
|28. Blocking Discriminator,鉴别阻塞|
|29. Cancelling Discriminator,鉴别取消|
|30. Structured Partial Join,结构化N选M|
|31. Blocking Partial Join,N选M阻塞|
|32. Cancelling Partial Join,N选M取消|
|33. Generalised AND-Join,AND合并|
|34. Static Partial Join for Multiple Instances,多实例的N选M|
|35. Cancelling Partial Join for Multiple Instances,多实例的N选M取消|
|36. Dynamic Partial Join for Multiple Instances,动态多实例的N选M|
|37. Local Synchronizing Merge,本地同步合并|
|38. General Synchronizing Merge,一般同步合并|
|39. Critical Section,区域互斥|
|40. Interleaved Routing,交叉路由|
|41. Thread Merge,线程合并|
|42. Thread Split,线程分支|
|43. Explicit Termination,显式终止|
[/table]


[color=red][size=large]2、控制流模式扩展排列[/size][/color]
[table]
|[b][size=x-large][color=blue]基本工作流模式[/color][/size] [/b]|
|1. Sequence,顺序|
|2. Parallel Split,并发分支|
|3. Synchronization,同步合并|
|4. Exclusive Choice,异或分支|
|5. Simple Merge,异或合并|
|[b][size=x-large][color=blue]高级分支、同步模式[/color][/size] [/b]|
|6. Multi-Choice,多路选择|
|7. Structured Synchronizing Merge,同步合并模式|
|8. Multi-Merge,多路合并|
|9. Structured Discriminator,结构化鉴别|
|28. Blocking Discriminator,鉴别阻塞|
|29. Cancelling Discriminator,鉴别取消|
|30. Structured Partial Join,结构化N选M|
|31. Blocking Partial Join,N选M阻塞|
|32. Cancelling Partial Join,N选M取消|
|33. Generalised AND-Join,AND合并|
|37. Local Synchronizing Merge,本地同步合并|
|38. General Synchronizing Merge,同步合并|
|41. Thread Merge,线程合并|
|42. Thread Split,线程分支|
|[b][size=x-large][color=blue]循环模式[/color][/size] [/b]|
|10. Arbitrary Cycles,循环|
|21. Structured Loop,结构化循环|
|22. Recursion,递归|
|[b][size=x-large][color=blue]终止模式[/color][/size] [/b]|
|11. Implicit Termination,隐式终止|
|43. Explicit Termination,显式终止|
|[b][size=x-large][color=blue]多实例模式[/color][/size] [/b]|
|12. Multiple Instances without Synchronization,异步多实例|
|13. Multiple Instances with a Priori Design-Time Knowledge,设计期多实例|
|14. Multiple Instances with a Priori Run-Time Knowledge,运行时前置多实例|
|15. Multiple Instances without a Priori Run-Time Knowledge,运行时非前置多实例|
|34. Static Partial Join for Multiple Instances,多实例的N选M|
|35. Cancelling Partial Join for Multiple Instances,多实例的N选M取消|
|36. Dynamic Partial Join for Multiple Instances,动态多实例的N选M|
|[b][size=x-large][color=blue]状态模式[/color][/size] [/b]|
|16. Deferred Choice,延迟选择|
|17. Interleaved Parallel Routing,乱序选择模式|
|18. Milestone,里程碑|
|39. Critical Section,区域互斥|
|40. Interleaved Routing,交叉路由|
|[b][size=x-large][color=blue]终止模式[/color][/size] [/b]|
|19. Cancel Activity,取消活动|
|20. Cancel Case,取消流程|
|25. Cancel Region,取消范围|
|26. Cancel Multiple Instance Activity,多实例的取消|
|27. Complete Multiple Instance Activity,多实例的手工完成|
|[b][size=x-large][color=blue]触发模式[/color][/size] [/b]|
|23. Transient Trigger,临时触发器|
|24. Persistent Trigger,持续触发器|
[/table]

这篇关于工作流_阐述_工作流模式(C1)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/888801

相关文章

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

工作常用指令与快捷键

Git提交代码 git fetch  git add .  git commit -m “desc”  git pull  git push Git查看当前分支 git symbolic-ref --short -q HEAD Git创建新的分支并切换 git checkout -b XXXXXXXXXXXXXX git push origin XXXXXXXXXXXXXX

模版方法模式template method

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/template-method 超类中定义了一个算法的框架, 允许子类在不修改结构的情况下重写算法的特定步骤。 上层接口有默认实现的方法和子类需要自己实现的方法

【iOS】MVC模式

MVC模式 MVC模式MVC模式demo MVC模式 MVC模式全称为model(模型)view(视图)controller(控制器),他分为三个不同的层分别负责不同的职责。 View:该层用于存放视图,该层中我们可以对页面及控件进行布局。Model:模型一般都拥有很好的可复用性,在该层中,我们可以统一管理一些数据。Controlller:该层充当一个CPU的功能,即该应用程序

迭代器模式iterator

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/iterator 不暴露集合底层表现形式 (列表、 栈和树等) 的情况下遍历集合中所有的元素

《x86汇编语言:从实模式到保护模式》视频来了

《x86汇编语言:从实模式到保护模式》视频来了 很多朋友留言,说我的专栏《x86汇编语言:从实模式到保护模式》写得很详细,还有的朋友希望我能写得更细,最好是覆盖全书的所有章节。 毕竟我不是作者,只有作者的解读才是最权威的。 当初我学习这本书的时候,只能靠自己摸索,网上搜不到什么好资源。 如果你正在学这本书或者汇编语言,那你有福气了。 本书作者李忠老师,以此书为蓝本,录制了全套视频。 试

嵌入式方向的毕业生,找工作很迷茫

一个应届硕士生的问题: 虽然我明白想成为技术大牛需要日积月累的磨练,但我总感觉自己学习方法或者哪些方面有问题,时间一天天过去,自己也每天不停学习,但总感觉自己没有想象中那样进步,总感觉找不到一个很清晰的学习规划……眼看 9 月份就要参加秋招了,我想毕业了去大城市磨练几年,涨涨见识,拓开眼界多学点东西。但是感觉自己的实力还是很不够,内心慌得不行,总怕浪费了这人生唯一的校招机会,当然我也明白,毕业

利用命令模式构建高效的手游后端架构

在现代手游开发中,后端架构的设计对于支持高并发、快速迭代和复杂游戏逻辑至关重要。命令模式作为一种行为设计模式,可以有效地解耦请求的发起者与接收者,提升系统的可维护性和扩展性。本文将深入探讨如何利用命令模式构建一个强大且灵活的手游后端架构。 1. 命令模式的概念与优势 命令模式通过将请求封装为对象,使得请求的发起者和接收者之间的耦合度降低。这种模式的主要优势包括: 解耦请求发起者与处理者

springboot实战学习(1)(开发模式与环境)

目录 一、实战学习的引言 (1)前后端的大致学习模块 (2)后端 (3)前端 二、开发模式 一、实战学习的引言 (1)前后端的大致学习模块 (2)后端 Validation:做参数校验Mybatis:做数据库的操作Redis:做缓存Junit:单元测试项目部署:springboot项目部署相关的知识 (3)前端 Vite:Vue项目的脚手架Router:路由Pina:状态管理Eleme

状态模式state

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/state 在一个对象的内部状态变化时改变其行为, 使其看上去就像改变了自身所属的类一样。 在状态模式中,player.getState()获取的是player的当前状态,通常是一个实现了状态接口的对象。 onPlay()是状态模式中定义的一个方法,不同状态下(例如“正在播放”、“暂停