activiti-并行网关

1.什么是并行网关

  并行网关允许将流程分成多条分支,也可以把多条分支汇聚在一起,并行网关的功能是基于进入和外出顺序流的;

  fork分支:

    并行后的所有外出顺序流,为每个顺序流都创建一个并发分支;

  join汇聚:

    所有达到并行网关,在此等待的进入分支,直到所有进入顺序的分支都达到以后,流程就会通过汇聚网关

  注意:如果同一个并行网关有多个进入和多个外出顺序流,它就同时具有分支和汇聚功能;这时,网关会先汇聚所有进入的顺序流,然后切分成多个并行分支;

  与其他网关的主要区别是,并行网关不会解析条件;及时顺序流中定义了条件,也会被忽略;

2.流程定义

  

  

3.测试

  3.1 部署流程

package com.wn.Par;

import org.activiti.engine.ProcessEngine;
import org.activiti.engine.ProcessEngines;
import org.activiti.engine.RepositoryService;

/*流程部署*/
public class Deployment {
    public static void main(String[] args) {
        //获取ProcessEngine
        ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
        //获取RepositoryService对象进行流程部署
        RepositoryService repositoryService = processEngine.getRepositoryService();
        //进行部署,将对应的流程定义文件生成到数据库当中,作为记录进行保存
        org.activiti.engine.repository.Deployment deployment= repositoryService.createDeployment()
                .addClasspathResource("bpmnfile/hoildayPar.bpmn")       //加载流程文件
                .addClasspathResource("bpmnfile/hoildayPar.png")
                .name("请假流程-并行网关")   //设置流程名称
                .key("hoildayPar-Key")
                .deploy();//部署
        //输出部署信息
        System.out.println("流程名称:"+deployment.getName());
        System.out.println("流程ID:"+deployment.getId());
        System.out.println("流程key:"+deployment.getKey());
    }
}

    

  3.2 启动流程

package com.wn.Par;

import org.activiti.engine.ProcessEngine;
import org.activiti.engine.ProcessEngines;
import org.activiti.engine.RuntimeService;
import org.activiti.engine.runtime.ProcessInstance;

import java.util.HashMap;
import java.util.Map;

/*启动流程实例*/
/*设置流程变量的值*/
public class StartInstance {
    public static void main(String[] args) {
        //获取ProcessEngine
        ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
        //获取RuntimeService
        RuntimeService runtimeService = processEngine.getRuntimeService();
        //设置流程变量  启动流程时设置
        //定义一个map集合,存放assignee的值
        Map<String ,Object> assMap=new HashMap<>();
        assMap.put("num",3);
        //启动一个流程实例
        ProcessInstance processInstance = runtimeService.startProcessInstanceByKey("hoildayPar", assMap);
        System.out.println("流程实例ID:"+processInstance.getId());
    }
}

    

  3.3 提交流程(zhangsan)

package com.wn.Par;

import org.activiti.engine.ProcessEngine;
import org.activiti.engine.ProcessEngines;
import org.activiti.engine.TaskService;
import org.activiti.engine.task.Task;

/*提交任务*/
public class CommitTask {
    public static void main(String[] args) {
        //获取ProcessEngine
        ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
        //获取TaskService对象
        TaskService taskService = processEngine.getTaskService();
        //查询到自己的任务,然后通过任务ID进行提交
        Task task = taskService.createTaskQuery().processDefinitionKey("hoildayPar").taskAssignee("zhangsan").singleResult();
        //任务处理
        taskService.complete(task.getId());
    }
}

    

  3.4 提交流程(lisi)

package com.wn.Par;

import org.activiti.engine.ProcessEngine;
import org.activiti.engine.ProcessEngines;
import org.activiti.engine.TaskService;
import org.activiti.engine.task.Task;

/*提交任务*/
public class CommitTask {
    public static void main(String[] args) {
        //获取ProcessEngine
        ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
        //获取TaskService对象
        TaskService taskService = processEngine.getTaskService();
        //查询到自己的任务,然后通过任务ID进行提交
        Task task = taskService.createTaskQuery().processDefinitionKey("hoildayPar").taskAssignee("lisi").singleResult();
        //任务处理
        taskService.complete(task.getId());
    }
}

    

  3.5 提交流程(zhaoliu)

package com.wn.Par;

import org.activiti.engine.ProcessEngine;
import org.activiti.engine.ProcessEngines;
import org.activiti.engine.TaskService;
import org.activiti.engine.task.Task;

/*提交任务*/
public class CommitTask {
    public static void main(String[] args) {
        //获取ProcessEngine
        ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
        //获取TaskService对象
        TaskService taskService = processEngine.getTaskService();
        //查询到自己的任务,然后通过任务ID进行提交
        Task task = taskService.createTaskQuery().processDefinitionKey("hoildayPar").taskAssignee("zhaoliu").singleResult();
        //任务处理
        taskService.complete(task.getId());
    }
}

    

    当执行到并行网关时,说明当前流程实例有多个分支在运行;

    并行任务不执行不分前后,有任务的负责人去执行即可;

    当所有分支达到汇聚结点,并行网关就执行完成了;

  3.6 提交流程(sunqi)

package com.wn.Par;

import org.activiti.engine.ProcessEngine;
import org.activiti.engine.ProcessEngines;
import org.activiti.engine.TaskService;
import org.activiti.engine.task.Task;

/*提交任务*/
public class CommitTask {
    public static void main(String[] args) {
        //获取ProcessEngine
        ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
        //获取TaskService对象
        TaskService taskService = processEngine.getTaskService();
        //查询到自己的任务,然后通过任务ID进行提交
        Task task = taskService.createTaskQuery().processDefinitionKey("hoildayPar").taskAssignee("sunqi").singleResult();
        //任务处理
        taskService.complete(task.getId());
    }
}

    

   3.7 提交流程(zhouba)

package com.wn.Par;

import org.activiti.engine.ProcessEngine;
import org.activiti.engine.ProcessEngines;
import org.activiti.engine.TaskService;
import org.activiti.engine.task.Task;

/*提交任务*/
public class CommitTask {
    public static void main(String[] args) {
        //获取ProcessEngine
        ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
        //获取TaskService对象
        TaskService taskService = processEngine.getTaskService();
        //查询到自己的任务,然后通过任务ID进行提交
        Task task = taskService.createTaskQuery().processDefinitionKey("hoildayPar").taskAssignee("zhouba").singleResult();
        //任务处理
        taskService.complete(task.getId());
    }
}

    执行完成后,整个流程就结束了;

    

 

猜你喜欢

转载自www.cnblogs.com/wnwn/p/12658727.html