jbpm4 foreach 实现动态分支

本文介绍如何利用Foreach活动在工作流引擎中实现多路径并发处理。通过配置Foreach及其配套的Join活动,可以高效地处理多个并行任务。示例中展示了如何为不同部门收集考勤报告。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

foreach 活动允许通过一条单独的流程路径 开始执行多条流程分支。 它的属性描述见下表。

foreach 属性:

属性 类型 默认值 是否必须? 描述
in 表达式或字符串   必须 将被迭代的集合。集合中的每个元素会生成一个新的同步分支 沿着默认的转移向外执行。in 执行任意类型的集合,数组和以逗号分隔的字符串。
var 字符串   必须 用来保存集合中当前元素的变量。 这个变量会设置到同步流程分支中, 并且只对这个流程分支可见。

 


在这个例子中,我们需要收集 不同部门的考勤表。同一个任务可以被不同的组织执行。 使用foreach就很容易实现了。 流程变量departments提供了所需要的组织名称, 同时,变量quota代表了多少个任务必须被完成, 在流程离开join之前。

<process name="ForEach" xmlns="http://jbpm.org/4.4/jpdl">  
  
   <start g="28,61,48,48" name="start1">  
      <transition to="foreach1"/>  
   </start>  
  
   <foreach var="department" in="#{departments}" g="111,60,48,48" name="foreach1">  
      <transition to="Collect reports"/>  
   </foreach>  
  
   <task candidate-groups="#{department}" g="201,58,92,52" name="Collect reports">  
      <transition to="join1"/>  
   </task>  
  
   <join g="343,59,48,48" multiplicity="#{quorum}" name="join1">  
      <transition to="end1"/>  
   </join>  
  
   <end g="433,60,48,48" name="end1"/>  
  
</process>  
<process name="ForEach" xmlns="http://jbpm.org/4.4/jpdl">

   <start g="28,61,48,48" name="start1">
      <transition to="foreach1"/>
   </start>

   <foreach var="department" in="#{departments}" g="111,60,48,48" name="foreach1">
      <transition to="Collect reports"/>
   </foreach>

   <task candidate-groups="#{department}" g="201,58,92,52" name="Collect reports">
      <transition to="join1"/>
   </task>

   <join g="343,59,48,48" multiplicity="#{quorum}" name="join1">
      <transition to="end1"/>
   </join>

   <end g="433,60,48,48" name="end1"/>

</process>

 
 

重要
在使用foreach的时候,对应的join必须设置一个multiplicity属性。 如果没有设置,join会根据它的进入转移来判断当前的流程是否需要继续流转。 在上面的例子里,join只有一个单独的进入转移。 如果multiplicity没有设置,第一个流程到达join活动 就会立刻触发继续执行离开join。

下面是如何初始化迭代用的流程变量。

view plaincopy to clipboardprint?
Map<String, Object> variables = new HashMap<String, Object>();   
variables.put("departments", new String[] { "sales-dept", "hr-dept", "finance-dept" });   
variables.put("quorum", 3);   
ProcessInstance processInstance = executionService.startProcessInstanceByKey("ForEach", variables);  

  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值