1.流程圖

2.執行代碼
package h_paralleGateWay;
import java.io.InputStream;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.activiti.engine.ProcessEngine;
import org.activiti.engine.ProcessEngines;
import org.activiti.engine.repository.Deployment;
import org.activiti.engine.runtime.ProcessInstance;
import org.activiti.engine.task.Task;
import org.junit.Test;
public class ParalleGateWayTest {
ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
/**部署流程定義(從inputStream)*/
@Test
public void deploymentProcessDefinition_inputStream(){
InputStream inputStreamBpmn = this.getClass().getResourceAsStream("paralleGateWay.bpmn");
InputStream inputStreamPng = this.getClass().getResourceAsStream("paralleGateWay.png");
Deployment deployment = processEngine.getRepositoryService()//與流程定義和部署對象相關的Service
.createDeployment()//建立一個部署對象
.name("排他網關")//添加部署的名稱
.addInputStream("paralleGateWay.bpmn", inputStreamBpmn)//
.addInputStream("paralleGateWay.png", inputStreamPng)//
.deploy();//完成部署
System.out.println("部署ID:"+deployment.getId());//
System.out.println("部署名稱:"+deployment.getName());//
}
/**啟動流程執行個體*/
@Test
public void startProcessInstance(){
//流程定義的key
String processDefinitionKey = "paralleGateWay";
ProcessInstance pi = processEngine.getRuntimeService()//與正在執行的流程執行個體和執行對象相關的Service
.startProcessInstanceByKey(processDefinitionKey);//使用流程定義的key啟動流程執行個體,key對應helloworld.bpmn檔案中id的屬性值,使用key值啟動,預設是按照最新版本的流程定義啟動
System.out.println("流程執行個體ID:"+pi.getId());//流程執行個體ID 101
System.out.println("流程定義ID:"+pi.getProcessDefinitionId());//流程定義ID helloworld:1:4
}
/**查詢目前人的個人任務*/
@Test
public void findMyPersonalTask(){
String assignee = "王小五";
List<Task> list = processEngine.getTaskService()//與正在執行的任務管理相關的Service
.createTaskQuery()//建立任務查詢對象
/**查詢條件(where部分)*/
.taskAssignee(assignee)//指定個人任務查詢,指定辦理人
// .taskCandidateUser(candidateUser)//組任務的辦理人查詢
// .processDefinitionId(processDefinitionId)//使用流程定義ID查詢
// .processInstanceId(processInstanceId)//使用流程執行個體ID查詢
// .executionId(executionId)//使用執行對象ID查詢
/**排序*/
.orderByTaskCreateTime().asc()//使用建立時間的升序排列
/**傳回結果集*/
// .singleResult()//傳回惟一結果集
// .count()//傳回結果集的數量
// .listPage(firstResult, maxResults);//分頁查詢
.list();//傳回清單
if(list!=null && list.size()>){
for(Task task:list){
System.out.println("任務ID:"+task.getId());
System.out.println("任務名稱:"+task.getName());
System.out.println("任務的建立時間:"+task.getCreateTime());
System.out.println("任務的辦理人:"+task.getAssignee());
System.out.println("流程執行個體ID:"+task.getProcessInstanceId());
System.out.println("執行對象ID:"+task.getExecutionId());
System.out.println("流程定義ID:"+task.getProcessDefinitionId());
System.out.println("########################################################");
}
}
}
/** 完成我的任務 */
@Test
public void completePersonalTask() {
// 任務id
String taskId = "4502";
Map<String, Object> variabes=new HashMap<String, Object>();
variabes.put("money", );
processEngine.getTaskService().complete(taskId,variabes);
System.out.println("完成任務:任務id:" + taskId);
}
}
說明:
1)一個流程中流程執行個體隻有1個,執行對象有多個
2)并行網關的功能是基于進入和外出的順序流的:
分支(fork): 并行後的所有外出順序流,為每個順序流都建立一個并發分支。
彙聚(join): 所有到達并行網關,在此等待的進入分支, 直到所有進入順序流的分支都到達以後, 流程就會通過彙聚網關。
3)并行網關的進入和外出都是使用相同節點辨別
4)如果同一個并行網關有多個進入和多個外出順序流, 它就同時具有分支和彙聚功能。 這時,網關會先彙聚所有進入的順序流,然後再切分成多個并行分支。
5)并行網關不會解析條件。 即使順序流中定義了條件,也會被忽略。
并行網關不需要是“平衡的”(比如, 對應并行網關的進入和外出節點數目不一定相等)。如圖中标示是合法的: