上一篇C++消息框架-基于sigslot文章中我们讲述了使用sigslot信号槽实现自己的消息框架,这是一个比较粗糙,而且小的框架。当我们的程序逐渐变大时,我们可能就会考虑功能插件化,或者支持某些模块动态加载和卸载。
功能动态加载,也就是我们平时所说的插件化,插件支持热插拔。
之前工作中,刚好接触过这一块的内容。下面是一个Qt加载dll的方式,当我们把dll加载上以后,可以尝试转化为PluginInterface接口,如果可以转换成功,则说明我们这个dll是我们需要的插件,然后我们就可以进行插件初始化。
如果插件代码需要和主程序通信,我们只需要在初始化插件的时候把相关参数传递进去即可。
void ReadPluginsInfo( const QString & pluginsDirPath /*= ""*/ )
{
QString pluginsPath = pluginsDirPath;
if (pluginsDirPath.isEmpty())
{
pluginsPath = QApplication::applicationDirPath();
}
QDir pluginsDir(pluginsPath);
pluginsDir.cd("Plugins");
QFileInfoList pluginsFile = pluginsDir.entryInfoList(QStringList() << "*.dll", QDir::Files);
foreach(QFileInfo fileInfo, pluginsFile)
{
QPluginLoader loader(fileInfo.absoluteFilePath());
bool isLoad = loader.isLoaded();
QString info = loader.errorString();
if (QObject * plugin = loader.instance())
{
if (PluginInterface * pinterface = dynamic_cast<PluginInterface *>(plugin))
{
pinterface->install(PluginParam());//初始化插件
m_lstPluginInterFace.push_back(pinterface);
}
}
else
{
qDebug() << loader.errorString();
}
}
}
上述代码伪代码如下:
void ReadPluginsInfo( const QString & pluginsDirPath /*= ""*/ )
{
进入插件路径
获取路径下所有dll
foreach(dll集合)
{
使用QPluginLoader加载动态库文件
if (转化为插件接口类)
{
初始化插件
}
}
}