上文研究了工作流的实例。这次我们来看看活动。
一、什么是活动
活动是WF中工作流处理的基本单位。每一个业务处理过程都是由活动组成的。例如,有一个把信息送到一系列的信息处理系统进行处理的任务,那么它的子活动可能会有:从数据库读取数据,使用这些数据生成一个文件,通过使用FTP或XML Web servcie把文件传到一个远程服务器上,标记信息已处理(如通过写入数据库并进入审计步骤)等。这些任务都是活动。
创建工作流时,这些单独的活动捆在一起,从一个转到另一个,一些活动可作为其他活动的窗口,一些活动执行单一任务。
活动如何知道本步骤完成后下一步做什么?或者活动会按你创建的root活动时指定的顺序执行,或者在一个特定的事件发生后才去执行指定的活动。我们首先看看WF Activity对象,然后看看活动是怎么链接到一起的。
二、活动相关对象和特性
Activity对象
Activity实现了一个可以与工作流交互的基类。活动对象由Activity对象派生,你可以定义自已的活动。
活动(Activity)的属性
属性 | 功能 |
Description | 获取或设置用户定义的关于活动的描述。 |
Enable | 获取或设置一个指明实例能否被执行和验证的值。 |
ExecutionResult | 获取实例最后运行的结果 (ActivityExecutionResult)。(有 Canceled、Compensated、Faulted、None 和 Succeeded)。 |
ExecutionStatus | 得到 workflow 的状态,其为 ActivityExecutionStatus 的枚举值(Canceling、Closed、Compensating、Executing、Faulting 和 Initialized)之一。 |
Name | 获取或设置活动实例的名称。 |
Parent | 获取包含本活动的父活动。 |
WorkflowInstanceId | 获取和该活动相关的 workflow 实例的标识符。 |
活动(Activity)的方法
属性 | 功能 |
Cancel | 取消活动的执行。 |
Clone | 返回活动的一个深拷贝。 |
Execute | 以同步方式运行活动。 |
GetActivityByName | 假如在一个组合活动上执行,本方法将返回组合活动中所包含的指定名称的活动。 |
Load | 从一个流中加载一个活动的实例。 |
RaiseEvent | 触发一个和指定的依赖属性相关的事件。 |
RaiseGenericEvent<T> | 触发和所引用的依赖属性相关的事件。RaiseEvent 和RaiseGenericEvent 的作用是一样的——第一个事件 RaiseEvent 直接指出 DependencyPropenty,而RaiseGenericEvent 则是一个泛型版本。 |
Save | 把活动保存到流中。 |
活动的方法都具有虚拟和受保护的特性。最关键的方法Execute被调用时,活动便开始执行了。
活动可分为组合活动和基本活动。
组合活动包含其他活动,如Sequential活动,它是所有顺序工作流活动的载体,可包含基本活动如Code活动、Delay活动等。基本活动执行单一的任务,由它们承载特定的任务。
ActivityExecutionContext对象
许多Activity对象的方法需要一个ActivityExecutionContext对象来进行输入。在workflow运行时把你要执行的workflow实例入队的时候,它便被创建了,因此它不是直接创建的对象。
ActivityExecutionContext对象的作用是提供方法和服务给活动。这些如初始化、定时器和产生执行流。它本质上是一个helper对象
依赖属性(Dependency Properties)
WF需要依赖属性来方便的进行活动的绑定。WF中的ActivityBind类可以方便的进行活动的绑定。
活动验证
活动通常都有验证的能力。像前面的IfElse活动,如果没有指定应该选择哪一个分支执行的条件时,VS会提醒我们。
三、Workflow类型
可以创建不同类型的workflow应用,很大程度上依赖于你选择的root活动。
实际运用中存在三种工作流:顺序工作流、状态机工作流和基于规则的工作流。
选择一种工作流
可依照你的业务处理需要选择不同的工作流。
顺序工作流自治执行,很少由外部控制,因此它不适合处理依赖于用户交互的特定任务,如审批任务。它的root活动是SequentialWorkflow活动。
状态机工作流严重依赖外部。因此需要大量用户交互,如你的工作流发送通知给其他用户或系统以使其他用户进行响应。它的root活动是StateMachineWorkflow活动。
基于的规则的工作流介于二者之间,root活动是顺序或状态活动。
四、状态活动
到现在我们还没有使用过状态机工作流。
假定已了解关于状态机的概念。在WF中基于状态的工作流内的个别状态由State活动创建。它是一个复合活动。
创建一个状态机工作流和顺序工作流一样,VS中模板中选择状态机工作流类型的程序即可。