Activiti——工作流程-核心API(二)

 .1 ProcessEngine

说明:

1) Activiti中最核心的类,其他的类都是由他而来。

2) 产生方式:

在前面看到了两种创建ProcessEngine(流程引擎)的方式(http://blog.csdn.net/u013490585/article/details/72858188),而这里要简化很多,调用ProcessEnginesgetDefaultProceeEngine方法时会自动加载classpath下名为activiti.cfg.xml文件。

3) 可以产生RepositoryService


4) 可以产生RuntimeService


5) 可以产生TaskService


各个Service的作用:

RepositoryService

管理流程定义

RuntimeService

执行管理,包括启动、推进、删除流程实例等操作

TaskService

任务管理

HistoryService

历史管理(执行完的数据的管理)

IdentityService

组织机构管理

FormService

一个可选服务,任务表单管理

ManagerService

使用Activiti的定制环境中基本上不会用到。 它可以查询数据库的表

和表的元数据。另外,它提供了查询和管理异步操作的功能。

.2RepositoryService

Activiti的仓库服务类。所谓的仓库指流程定义文档的两个文件:bpmn文件和流程图片。

1) 产生方式

2) 可以产生DeploymentBuilder,用来定义流程部署的相关参数

3) 删除流程定义

.3RuntimeService

activiti的流程执行服务类。可以从这个服务类中获取很多关于流程执行相关的信息。

.4TaskService

activiti的任务服务类。可以从这个类中获取任务的信息。

.5HistoryService

activiti的查询历史信息的类。在一个流程执行完成后,这个对象为我们提供查询历史信息。

.6ProcessDefinition

流程定义类。可以从这里获得资源文件等。

.7ProcessInstance

 代表流程定义的执行实例,如员工请假,该员工就必须发出一个流程实例的申请,一个流程实例包括了所有的运行节点。

我们可以利用这个对象来了解当前流程实例的进度等信息。流程实例就表示一个流程从开始到结束的最大的流程分支

即一个流程中流程实例只有一个。

.8Execution

Activiti用这个对象去描述流程执行的每一个节点。在没有并发的情况下,Execution就是同ProcessInstance流程按照流程定义的规则执行一次的过程,就可以表示执行对象Execution

如图为ProcessInstance的源代码:

 

 

从源代码中可以看出ProcessInstance就是Execution。但在现实意义上有所区别:

 

 

在单线流程中,如上图的贷款流程,ProcessInstance与Execution是一致的。

 

 

这个例子有一个特点:wire money(汇钱)和archive(存档)是并发执行的。 这个时候,总线路代表ProcessInstance,而分线路中每个活动代表Execution。

总结:

一个流程中,执行对象可以存在多个,但是流程实例只能有一个。

当流程按照规则只执行一次的时候,那么流程实例就是执行对象。

 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值