osworkflow的工作流工厂
我们知道,osworkflow系统对osworkflow.xml中的
<factory class="com.opensymphony.workflow.loader.XMLWorkflowFactory">
<property key="resource" value="workflows.xml" />
</factory>
以及对workflows.xml的
<workflows>
<workflow name="example" type="resource" location="/samples/comment-arg.xml"/>
</workflows>
解析,是放在workflowFactory中进行的;osworkflow的工作流工厂有几大类:
1)com.opensymphony.workflow.loader.XMLWorkflowFactory
2)com.opensymphony.workflow.loader.JDBCWorkflowFactory
3)com.opensymphony.workflow.loader.URLWorkflowFactory
他们都extends AbstractWorkflowFactory,并且他们的真正实现都是调用
WorkflowLoader.load(url)而实现的,所以他们的实现方法基本上是一样的,只不过他们的
cache实现方式不尽相同:
1)com.opensymphony.workflow.loader.XMLWorkflowFactory cache WorkflowConfig
2)com.opensymphony.workflow.loader.JDBCWorkflowFactory cache WfConfig
3)com.opensymphony.workflow.loader.URLWorkflowFactory cache WorkflowDescriptor(www.iocblog.net 文章来源)
我们举例看看XMLWorkflowFactory的代码:
WorkflowConfig c = (WorkflowConfig) workflows.get(name);(www.iocblog.net 文章来源)
if (c == null) {
throw new FactoryException("Unknown workflow name \"" + name + "\"");
}
if (c.descriptor != null) {
if (reload) {
File file = new File(c.url.getFile());
if (file.exists() && (file.lastModified() > c.lastModified)) {
c.lastModified = file.lastModified();
loadWorkflow(c);
}
}
}
else {
loadWorkflow(c);
}
return c.descriptor;
大家应该看到上面的代码就明白了,它用的是flyweight模式,只不过加了个中间层
WorkflowConfig而已;AgileFlow引擎对流程定义的解析使用的也是这个模式,它能够
实时判断用户对流程定义的修改并做出相应的反应.
文章整理:iocblog
版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。