在JBPM中,创建的是全局单例的ProcessEngine(在Configuration类中).
为什么JBPM的ProcessEngine?
因为在JBPM系统中,不可能有很多个用户登陆,每个用户分配一个ProcessEngine.肯定全局就一个ProcessEngine,为所有用户进行服务.具体可见下面代码(也是一个标准的单例模式例子):
Configuration类
/** singletone instance */
private static ProcessEngine singleton; //流程引擎静态实例
#单例模式第一点:创建一个静态的实例.
public static ProcessEngine getProcessEngine() {//单例
if (singleton == null) {//判断静态实例是否存在
synchronized (Configuration.class) {//排他的执行,保证实例是唯一的一个
if (singleton == null) {
singleton = new Configuration().setResource("jbpm.cfg.xml").buildProcessEngine();
}
}
}
return Configuration.singleton;
}
#单例模式第二点:这是代码的严谨性,很多人会忽略考虑并发访问,而没有加一个类锁.为什么要加一个synchronized关键字?因为当多个用户同时访问或多线程访问时,会导致一个问题,他们同时得到Configuration类实例为空,所以会创建多个实例.
#所以在执行最里面的代码之前,必须获得类锁.这样就可以保证实例的唯一性.