09-jbpm工作流之"分支聚合Join-Fork"
来源:互联网 发布:淘宝哪里有卖听话水 编辑:程序博客网 时间:2024/06/06 02:35
工作流的分支与聚合:
这是多个分支并行(同时)执行,并且所有的分支Execution都到Join活动聚合后才向后执行;
1.工作流图:test.png
工作流配置文件:test.jpdl.xml:
<?xml version="1.0" encoding="UTF-8"?><process name="test" xmlns="http://jbpm.org/4.4/jpdl"> <start g="255,8,48,48" name="start1"> <transition g="-51,-13" name="to fork1" to="fork1"/> </start> <end g="260,354,48,48" name="end1"/> <fork g="258,95,48,48" name="fork1"> <transition g="-23,-20" name="to 发货" to="发货"/> <transition g="-12,-20" name="to 汇款" to="汇款"/> </fork> <task assignee="商家" g="88,111,92,52" name="发货"> <transition g="-44,-9" name="to 收货" to="收货"/> </task> <task assignee="客户" g="87,193,92,52" name="收货"> <transition g="-18,-23" name="to join1" to="join1"/> </task> <task assignee="客户" g="385,115,92,52" name="汇款"> <transition g="-70,-15" name="to 确认收货" to="确认收款"/> </task> <task assignee="商家" g="384,205,92,52" name="确认收款"> <transition g="-24,-21" name="to join1" to="join1"/> </task> <join g="260,257,48,48" name="join1"> <transition g="-50,-11" name="to end1" to="end1"/> </join></process>
JAVA Code:
package cn.edu.zust.itee.joinFork;import java.io.InputStream;import java.util.List;import org.jbpm.api.Configuration;import org.jbpm.api.ProcessEngine;import org.jbpm.api.ProcessInstance;import org.jbpm.api.task.Task;import org.junit.Test;/** * @author 郑勇 * 2013-7-11 13:50 * 分支聚合活动 * 这是多个分支并行(同时)执行,并且所有的分支Execution都到Join活动聚合后才向后执行; */public class JoinFork { ProcessEngine processEngine= Configuration.getProcessEngine();@Testpublic void testJoinForkActivity(){//部署流程定义//获得当前包中的文件InputStream in = this.getClass().getResourceAsStream("test.jpdl.xml");processEngine.getRepositoryService() .createDeployment() .addResourceFromInputStream("test.jpdl.xml", in) .deploy();//启动流程实例ProcessInstance pi = processEngine.getExecutionService().startProcessInstanceByKey("test");System.out.println("processIntenceId="+pi.getId());System.out.println("当前正在执行的活动:"+pi.findActiveActivityNames());//完成"发货"和"汇款"任务List<Task> list = processEngine.getTaskService().createTaskQuery() //查询出该流程实例中分支任务 .processInstanceId(pi.getId()) .list();for(Task task :list){//活动按自己的分支执行processEngine.getTaskService().completeTask(task.getId());} }}
- 09-jbpm工作流之"分支聚合Join-Fork"
- 工作流jbpm中join与fork用法
- jbpm工作流引擎之分支结构
- jbpm流程设计之fork、join
- JBPM知识点------fork、join
- jbpm fork join
- JBPM知识点------fork、join
- JBPM具体应用之fork,join,state节点的使用
- 工作流 之JBPM简介
- jbpm知识点——fork、join
- jbpm知识点——fork、join
- Fork/Join框架之Fork、Join操作
- Fork/Join框架之Fork、Join操作
- Fork/Join框架之Fork、Join操作
- jdk7之fork-join
- JBPM源码解读之:Fork
- jBPM-4.4:fork和join的一个例子
- jbpm分叉并行fork节点会和节点join
- Extjs学习进度条
- 使用mmap进行进程间内存共享
- 理解ORACLE数据库字符集
- Hibernate缓存应用(积累与总结)
- iPhone 判断是否插入sim卡
- 09-jbpm工作流之"分支聚合Join-Fork"
- JavaScript中的对象(一)
- 计算一个字节(8位)里面,1的个数
- 十年技术,不要再迷茫
- Agile开发学习笔记
- ASP.NET 中如何对生成的 HTML 内容流进行控制?
- Android开发:ListView加上滚动滑块
- eclipse 加入php支持 极其简单 笔记
- 关于php存储cookie时path存放路径放的详细介绍