网关
网关是用于控制流程的走向,也成为执行令牌,根据功能不同可以分为:排他网关,并行网关,包容网关,事件网关。
排他网关
排他网关(exclusive-gateway) 也称为 XOR gateway,用来对流程中的决定进行建模,流程执行到该网关是,按照输出流的顺序逐个计算,当条件为true时,继续执行该网关的输出。
值得注意的是,在排他网关中,如果多个线路的计算都为true,那么只会执行第一个为true的网关,忽略其他表达式为true的网关。
对应的XML描述:
<exclusiveGateway id="exclusive" default="_5" />
排他网关案例:
<process id="myProcess_1" isClosed="false" isExecutable="true" processType="None">
<startEvent activiti:initiator="xixi" id="start" name="StartEvent"/>
<exclusiveGateway id="exclusive" name="exclusive gateway" default="flow2">
</exclusiveGateway>
<sequenceFlow id="flow1" sourceRef="start" targetRef="exclusive">
</sequenceFlow>
<userTask id="userTask1" name="task1" >
</userTask>
<sequenceFlow id="flow2" name="${type=1}" sourceRef="exclusive" targetRef="userTask1">
<conditionExpression xsi:type="tFormalExpression">
<![CDATA[${type=1}]]>
</conditionExpression>
</sequenceFlow>
<userTask id="userTask2" name="task2" >
</userTask>
<sequenceFlow id="flow3" name="${type=2}" sourceRef="exclusive" targetRef="userTask2">
<conditionExpression xsi:type="tFormalExpression">
<![CDATA[${type=2}]]>
</conditionExpression>
</sequenceFlow>
<userTask id="userTask3" name="task3" >
</userTask>
<sequenceFlow id="flow4" name="${type=3}" sourceRef="exclusive" targetRef="userTask3">
<conditionExpression xsi:type="tFormalExpression">
<![CDATA[${type=3}]]>
</conditionExpression>
</sequenceFlow>
</process>
并行网关
并行网关是对并发的任务进行建模处理,它能把单条线路拆分成多个路径并行执行,或者将多个路径合并处理。
对应的XML描述:
<parallelGateway id="parallel" name="parallel gateway" >
</parallelGateway>
并行网关的功能决定于输入和输出顺序流:
- 拆分
并行执行所有的输出顺序流,并且为每一条顺序流创建一个并行执行线路 -
合并
所有从并行网关拆分并执行完成的线路都在此等候,直到所有线路都执行完成才继续向下执行
并行网关如果设置了条件,直接会被忽略掉。
并行网关案例:
<process id="myProcess_1" isClosed="false" isExecutable="true" processType="None">
<startEvent activiti:formKey="leave" activiti:initiator="xixi" id="start" name="StartEvent"/>
<endEvent id="end" name="EndEvent"/>
<userTask activiti:exclusive="true" id="_3" name="UserTask"/>
<userTask activiti:exclusive="true" id="_4" name="UserTask"/>
<userTask activiti:exclusive="true" id="_5" name="UserTask"/>
<parallelGateway gatewayDirection="Unspecified" id="_2" name="ParallelGateway"/>
<parallelGateway gatewayDirection="Unspecified" id="_6" name="ParallelGateway"/>
<endEvent id="_7" name="EndEvent"/>
<sequenceFlow id="_8" sourceRef="start" targetRef="_5"/>
<sequenceFlow id="_9" sourceRef="_5" targetRef="_2"/>
<sequenceFlow id="_10" sourceRef="_2" targetRef="_4"/>
<sequenceFlow id="_12" sourceRef="_6" targetRef="_7"/>
<sequenceFlow id="_13" sourceRef="_2" targetRef="_3"/>
<sequenceFlow id="_11" sourceRef="_3" targetRef="_6"/>
<sequenceFlow id="_14" sourceRef="_4" targetRef="_6"/>
</process>
包容网关
包容网关融合了排他网关和并行网关的特性,排他网关允许在每条线路上设置条件,并行网关可以同时执行多个线程,包容网关既可以执行多个线路又允许在网关上设置条件。
<inclusiveGateway id="inclusive" name="inclusive gateway" >
</inclusiveGateway>
- 拆分
计算每条线路上的表达式,当表达式为true的时候,创建一个并行线路并继续执行 -
合并
所有从并行网关拆分并执行完成的线路均再次等候,直到所有线路都执行完才继续执行。
包容网关案例:
<process id="myProcess_1" isClosed="false" isExecutable="true" processType="None">
<startEvent activiti:formKey="leave" activiti:initiator="xixi" id="start" name="StartEvent"/>
<endEvent id="end" name="EndEvent"/>
<userTask activiti:exclusive="true" id="_3" name="UserTask"/>
<userTask activiti:exclusive="true" id="_4" name="UserTask"/>
<userTask activiti:exclusive="true" id="_5" name="UserTask"/>
<endEvent id="_7" name="EndEvent"/>
<sequenceFlow id="_8" sourceRef="start" targetRef="_5"/>
<inclusiveGateway gatewayDirection="Unspecified" id="_15" name="InclusiveGateway"/>
<inclusiveGateway gatewayDirection="Unspecified" id="_16" name="InclusiveGateway"/>
<sequenceFlow id="_17" sourceRef="_5" targetRef="_15"/>
<sequenceFlow id="_18" sourceRef="_15" targetRef="_3">
<conditionExpression xsi:type="tFormalExpression"><![CDATA[type=1]]></conditionExpression>
</sequenceFlow>
<sequenceFlow id="_19" sourceRef="_3" targetRef="_16"/>
<sequenceFlow id="_2" sourceRef="_16" targetRef="_7"/>
<sequenceFlow id="_6" sourceRef="_15" targetRef="_4">
<conditionExpression xsi:type="tFormalExpression"><![CDATA[type=2]]></conditionExpression>
</sequenceFlow>
<sequenceFlow id="_9" sourceRef="_4" targetRef="_16"/>
</process>
事件网关
事件网关是专门为中间捕获事件设置的,它允许设置多个输出流指向多个不同的中间捕获事件。
子流程
子流程就是把一系列需要处理的任务归结到大流程的一部分,就叫做子流程。
对应的XML描述:
<subProcess id="sub" name="sub process">
</subProcess>
对子流程的一些限制
- 只能包含一个空启动事件
- 至少要有一个结束事件
- 在子流程中顺序流程不能直接设置输出到子流程以外的活动上
事件子流程
事件子流程和子流程类似,不同的是事件子流程不能直接启动,需要被动启动,需要其他事件触发
对应的XML描述:
<subProcess id="sub" name="sub process" triggeredByEvent = "true">
</subProcess>
事物子流程
事物子流程也称为事务块,用来处理必须在同一个事务中完成的活动,满足事务的特性。
对应的XML描述:
<transaction id="transaction">
</transaction>