繁体   English   中英

QPluginLoader实例始终返回null

[英]QPluginLoader instance always returns null

我正在构建Qt应用程序。 虽然我之前已经编写了许多GUI东西,而框架本身并没有出现问题,但我从未编程过任何能够加载插件的东西(C#.NET应用程序之外)。 我正在尝试构建的项目将插件作为其不可或缺的一部分,我认为Qt框架对此看起来不错,因为它几乎普遍都是跨平台的,并且似乎有一个非常好的插件系统。

我的问题是: 我似乎无法让QPluginLoader.instance()方法返回除null值之外的任何值

根据我的阅读,这是因为它找不到插件。 我想我可能忘了做某事,但是我发现关于实际编写插件的文档很少(有示例,但是没有详尽介绍)。 有很多加载插件的例子,我想我做对了,但是我还没有找到实际制作插件的例子。

这是我所做的:

使用Qt-Creator,我创建了两个项目:一个假装是我的插件接收应用程序的窗口应用程序,以及一个假装是插件的共享库项目。

在窗口应用程序中,我有一个头文件,如下所示:

#ifndef PLUGININTERFACE_H
#define PLUGININTERFACE_H

#include <QtPlugin>

class QStringList;

class PluginInterface
{
public:
    virtual ~PluginInterface() {};

    virtual QStringList messages() const = 0;
};

Q_DECLARE_INTERFACE(PluginInterface,
                    "com.kevincuzner.LearningPlugins.PluginInterface/1.0")

#endif // PLUGININTERFACE_H

在我的共享库应用程序中,我创建了一个名为ATestPlugin的类(这也是项目的TARGET值):

#ifndef ATESTPLUGIN_H
#define ATESTPLUGIN_H

#include "ATestPlugin_global.h"
#include "../LearningPlugins/PluginInterface.h"

#include <QStringList>


class ATESTPLUGINSHARED_EXPORT ATestPlugin : public PluginInterface, public QObject
{

    Q_OBJECT
    Q_INTERFACES(PluginInterface)

public:
    ATestPlugin();

    virtual QStringList messages() const
    {
        //this part is actually defined in the .cpp file, but I don't feel like pasting that here
        QStringList ret;
        ret << "foo" << "bar" << "noms" << "Hello";

        return ret;
    }
};

#endif // ATESTPLUGIN_H

在ATestPlugin.cpp文件的末尾,我放置了Q_EXPORT_PLUGIN2(ATestPlugin, ATestPlugin)

然后在main方法的main.cpp文件中,执行以下操作(&w指向主窗口):

QString text = QFileDialog::getOpenFileName(&w, "Get a file");
QPluginLoader loader(text);
QObject* plugin = loader.instance();
if (plugin)
{
    QMessageBox msgBox;
    msgBox.setText(text);
    msgBox.exec();
}

当我运行程序并在弹出的文件对话框中从库项目的构建目录中选择libATestPlugin.so时,我看不到任何消息框,这意味着* plugin为null。 以前,我总是弹出消息框并显示选定的文件名,因此我知道该部分正在工作。

是否有人对我的插件对QPluginLoader可见有什么想法?

它对我不起作用。 将您以前的TARGET更改为$$ qtLibraryTarget(...),可以确保在不同平台上进行构建时的正确扩展。

我在QPluginLoader中遇到了同样的问题。 简而言之,我是如何解决的:我创建了插件库,比如说lib1.dll,它使用来自lib2.dll的一些东西。 在我的应用程序中,我尝试通过QPluginLoader加载lib1。

QPluginLoader loader( adaptersDir.absoluteFilePath(fileName) );
AdapterInterface* adapterIface = qobject_cast<AdapterInterface*>(loader.instance());

在这种情况下,loader.instance()返回0。解决方法是将lib2.dll复制到应用程序文件夹中,因为应用程序将其用于正确的加载插件lib1。

经过进一步的实验,我设法加载了插件。 我这么说让我感到有些毛骨悚然,但这是RTFM的经典案例。

echo插件教程 (直到我发布问题后才找到),必须对库中的.pro文件进行一些修改才能使其正确声明插件:

TARGET = ATestPlugin必须更改为TARGET = $$qtLibraryTarget(ATestPlugin) 进行此更改后,在上述程序中弹出我的消息框,稍后当我运行qobject_cast< PluginInterface* >(plugin) ,然后要求运行PluginInterface->messages()我得到了在单独的类中实现的列表。

另外,我确实更改了继承顺序,将QObject放在首位,并且因为它以这种方式工作,所以我可能会保持它不变(尽管我不知道它是否有所作为)。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM