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
版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。

相关项目