Qt:QPluginLoader与插件式开发

一个工程中,不同的界面就可能由不同的模块进行管理开发,然后生成相应的dll。一般状况下,直接加载.dll创建对象的话,当这个.dll丢失的时候,程序就会直接报错,无法运行下去。
但当我们利用插件式开发,结合QPluginLoader,就可以做到即使.dll丢失,主程序也不会崩溃,只会丢失相应的功能。

1.首先自定义插件抽象基类

函数根据需要自行添加。

class IPlugin : public QObject
{
public:
	virtual ~IPlugin() {}

public:
	virtual void initialize() = 0;
	virtual QString pluginName() const = 0;	
	virtual QString pluginDescr() const = 0;
	virtual QStringList pluginWidgets() const = 0;
	virtual QMap<QString, QWidget*> createWindow(const QString& name, QWidget* parent) = 0; 
};
2.创建具体插件类
class MyPlugin : public IPlugin
{
	Q_OBJECT

		Q_INTERFACES(IPlugin)
		Q_PLUGIN_METADATA(IID ICNCPlugin_iid FILE  "MyPlugin.json")

public:
	virtual void initialize() override;
	virtual QString pluginName() const override;
	virtual QString pluginDescr() const override;
	virtual QStringList pluginWidgets() const override;
	virtual QMap<QString, QWidget*> createWindow(const QString& name, QWidget* parent) override;

private:
	QMap<QString, QWidget*> pluginPageGroup;
};

注意,Q_PLUGIN_METADATA该宏必须得声明,不然后面QPluginLoader会无法加载该模块,详见Qt帮助文档。
创建完具体插件类后,把接口实现。

3.创建插件管理类

用单例模式。

//PluginManager.h
class cPluginManager
{
public:
	cPluginManager();
	~cPluginManager();

private:
	static cPluginManager *mPluginManager;
	QMap<QString, IPlugin*> mLoadedPlugins;

public:
	static cPluginManager* getInstance();

private:
	void loadPlugins();
	void releasePlugins();

public:
	QList<IPlugin*> getLoadedPlugins();
	IPlugin* getPluginByName(QString pluginName);

private:
	class gc
	{
	public:
		~gc()
		{
			if (mPluginManager)
			{
				delete mPluginManager;
				mPluginManager = nullptr;
			}
		}
	};
	static gc delgc;
};
//PluginManager.cpp
//加载插件
void cPluginManager::loadPlugins()
{
	QDir pluginsDir(QCoreApplication::applicationDirPath() + "");//dll所在文件夹

	QStringList loadedPluginFileNames;
	for (const QString& fileName : pluginsDir.entryList(QDir::Files))
	{
		if (!fileName.contains(".dll"))
			continue;

		if (loadedPluginFileNames.contains(fileName))
			continue;
			
		QPluginLoader pluginLoader(pluginsDir.absoluteFilePath(fileName));
		QObject *plugin = pluginLoader.instance();
		QString error = pluginLoader.errorString();
		if (plugin)
		{
			IPlugin *myPlugin = qobject_cast<IPlugin*>(plugin);
			if (myPlugin )
			{
				myPlugin ->initialize();
				auto name = myPlugin ->pluginName();
				mLoadedPlugins.insert(name, myPlugin );
				loadedPluginFileNames.push_back(fileName);
			}
			else
			{
				delete plugin;
				plugin = nullptr;
			}
		}
	}
}
4.主界面调用

至此插件已加载完毕,用相应的容器接住QWidget,便可以进行相应操作。

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Qt QPluginLoaderQt 框架中的一个类,用于动态加载件并在运行时创建件实例。 通过 QPluginLoader,您可以将 Qt 件(也称为共享库或动态链接库)加载到您的应用程序中。这些件可以包含任何类型的功能,例如界面元素、数据存储、网络通信等等。 要使用 QPluginLoader,您需要提供件的路径,并使用 load() 方法加载件。如果加载成功,您可以使用 instance() 方法创建件实例,并与其交互。 以下是 QPluginLoader 的简单示例: ``` #include <QApplication> #include <QPluginLoader> #include <QDebug> #include "myplugin.h" int main(int argc, char *argv[]) { QApplication a(argc, argv); QPluginLoader loader("myplugin.dll"); QObject *plugin = loader.instance(); if (plugin) { MyPlugin *myPlugin = qobject_cast<MyPlugin *>(plugin); if (myPlugin) { myPlugin->doSomething(); } else { qWarning() << "Failed to cast plugin to MyPlugin"; } } else { qWarning() << loader.errorString(); } return a.exec(); } ``` 在此示例中,我们加载名为 "myplugin.dll" 的件,并使用 qobject_cast 将其转换为 MyPlugin 类型。如果转换成功,我们调用 doSomething() 方法执行件中的操作。 需要注意的是,QPluginLoader 只能用于加载 Qt 件,而不是任意的共享库或动态链接库。要创建 Qt 件,您需要使用 Qt Creator 或 qmake 工具创建一个项目,并将其编译为共享库。详情请参阅 Qt 文档。 ### 回答2: QtQPluginLoader是一个用于加载Qt件的类。它可以加载动态链接库,并获取件的元对象信息,从而可以在运行时动态实例化该件。 QPluginLoader提供了一种使用Qt件的灵活机制。件是一种通过将功能模块拆分为单独的动态链接库来扩展应用程序的方。使用件可以使应用程序更易于维护和扩展。 QPluginLoader可以通过指定件路径或文件名来加载件。在加载件之后,可以使用其metaObject()方法获得件的元对象,进而实例化件并访问其属性和方法。 使用QPluginLoader可以实现件的热拔功能。如果件的路径或文件名发生变化,可以通过重新加载件来更新应用程序的功能,而无需重新编译整个应用程序。 除了动态加载Qt件以外,QPluginLoader还有其他一些功能。例如,它可以检查件是否已加载,获取件的元数据(包括依赖关系和元数据版本),以及在件加载失败时获取错误信息。 总之,QPluginLoaderQt提供的一个强大的工具,它简化了Qt件的加载和使用过程,使应用程序更具灵活性和可扩展性。使用QPluginLoader开发人员可以更方便地实现件机制,并轻松地将件集成到应用程序中。 ### 回答3: QtQPluginLoader类是一种用于加载件的工具。 件是一种外部提供的、可扩展的模块,可以在应用程序中动态加载和卸载。 QPluginLoader提供了一种方便、灵活的方法来加载这些件,并在运行时使用它们。 QPluginLoader的主要功能之一是加载件。它可以从文件系统中加载指定的件文件,并将其加载到当前应用程序中。件文件一般具有动态链接库(DLL)的格,其中包含了件的实现代码。加载件时,QPluginLoader会自动查找并加载件所需的依赖库,以确保件能够正确执行。 加载件后,QPluginLoader提供了一种检查件状态和使用件的方。它可以提供件的元数据,如件的名称、版本和作者等信息。QPluginLoader还提供了一种用于获取件接口的方法,可以使用这些接口来调用件的功能。使用件接口,应用程序可以与件进行通信,并根据需要执行件所提供的功能。 另外,QPluginLoader还支持动态加载和卸载件。这意味着应用程序可以在运行时根据需要加载或卸载件,从而实现动态扩展功能。这对于需要灵活性和模块化的应用程序来说非常有用,可以根据应用程序环境的变化加载不同的件,从而实现不同的功能。 总的来说,QPluginLoaderQt中一个非常有用的工具类,它提供了一种方便的方法来加载、管理和使用件。使用QPluginLoader开发人员可以轻松地将件集成到应用程序中,实现更灵活和可扩展的应用程序架构。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值