pfw从2.0开始必须初始化后才能使用(为了提高开发时的稳定性,同时可以更好的实现模块化加载,与其它框架更好的协同工作)
初始化方式有以下两种:
- 全局初始化函数
pfwInitialize([flags]) //初始化环境,flags可选(见Enums.INIT_FLAG_XXX,支持组合)
pfwFinalize //反初始化环境
pfwInitialize 一般情况下分别放在Application Open事件最开头
pfwFinalize 放在Application Close事件的最后
⚠️ pfwFinalize必须与pfwInitialize配对使用。
- 继承初始化对象实现自动初始化
继承pfw.common.pbl::n_initializer对象,开启[AutoInstantiate]属性,将对象实例放在全局变量里,这样就可以实现自动初始化环境
n_initializer有一些属性开关,与Enums.INIT_FLAG_XXX枚举值是等价的,根据需要开启对应的功能模块
使用自动实例化的好处是可以在开发模式下直接右键运行对象来调试,但这种方式可能会有不稳定的情况出现,因为PB对全局自动实例化对象的生命期管理不受我们的用户代码控制,它的释放时机可能会引起访问冲突(这种情况可能会出现)
pfw初始化时可以显式指定需要初始化的第三方模块,没有显式初始化的模块其相关功能不可使用并且不需要附带相应的DLL文件,以下代码展示开启Sciter模块:
pfwInitialize(Enums.INIT_FLAG_ENABLE_SCITER)
⚠️ 运行时需要附带sciter.dll,否则初始化将失败。
- 是否支持Windows XP?
从3.0开始pfw不再保证继续支持XP
- 连接ORACLE之后在开发模式(IDE)下运行第二次可能出现加载pfw.dll报错
解决方法为将pfw.dll所在目录加入到PATH
环境变量中
造成此问题的原因是OCI驱动会改变dll加载搜索路径 (编译EXE后不受此影响)