【Qt QML】QLibrary加载共享库中的类

QLibrary是一个用于加载动态链接库(或称为共享库)的类。它提供了一种独立于平台的方式来访问库中的功能。

在QLibrary中,可以通过构造函数或setFileName()方法设置要加载的库文件名。当加载库文件时,QLibrary会搜索所有平台特定的库位置,除非传入的文件名具有绝对路径。如果传入的文件名具有绝对路径,那么会首先尝试加载该目录。如果该文件找不到,QLibrary会使用不同的平台特定的文件前缀或后缀再次尝试。例如,在Unix和Mac平台上使用"lib"前缀,在Unix平台上使用".so"后缀,在Mac平台上使用".dylib",在Windows平台上使用".dll"。

使用QLibrary可以在程序运行时加载动态链接库,一个QLibrary的实例作用于一个单一的共享库上。QLibrary提供了一种平台无关的方式访问库中的函数。此外,通过调用load()函数加载链接库,使用isLoad()函数判断加载是否成功,使用resolve()与load()差不多,但是当如果load失败,将会尝试再次加载。当经过一次加载后,链接库将会存储到内存中直到应用程序退出。使用unload()函数解除,如果有多个QLibrary使用了同一个动态链接库unload()将返回false。

下面的例子用来演示如何运行时加载共享库中的类

一、创建一个共享库

1、打开Qt Creator,创建共享库,新建类TestPlugin

TestPlugin.h

cpp 复制代码
#ifndef TESTPLUGIN_H
#define TESTPLUGIN_H

#include "testPlugin_global.h"

class TESTPLUGIN_EXPORT TestPlugin
{
public:
    virtual ~TestPlugin();
    virtual int TestAddFunc(int a, int b) = 0;
};

class TESTPLUGIN_EXPORT TestPluginLib : public TestPlugin
{
public:
    virtual ~TestPluginLib();
    int TestAddFunc(int a, int b) override;
};

extern "C"{
TESTPLUGIN_EXPORT void* createTestPlugin();
}

#endif // TESTPLUGIN_H

TestPlugin.cpp

cpp 复制代码
#include "testplugin.h"

TestPlugin::~TestPlugin()
{

}

void *createTestPlugin()
{
    return new TestPluginLib();
}

TestPluginLib::~TestPluginLib()
{

}

int TestPluginLib::TestAddFunc(int a, int b)
{
    return a+b;
}

2、导出宏定义

cpp 复制代码
#ifndef TESTPLUGIN_GLOBAL_H
#define TESTPLUGIN_GLOBAL_H

#include <QtCore/qglobal.h>

#if defined(TESTPLUGIN_LIBRARY)
#define TESTPLUGIN_EXPORT Q_DECL_EXPORT
#else
#define TESTPLUGIN_EXPORT Q_DECL_IMPORT
#endif

#endif // TESTPLUGIN_GLOBAL_H
二、新建动态库加载demo,加载方式如下:
cpp 复制代码
	using pluginFunc = void*(*)();

    QLibrary lib("testPlugin");
    if(!lib.load()){
        qCritical() <<__FUNCTION__<<" load error!";
        return -1;
    }

    auto func = (pluginFunc)lib.resolve("createTestPlugin");

    TestPlugin* cppLibObj = static_cast<TestPlugin*>(func());
    if(!cppLibObj)
    {
        qCritical() <<__FUNCTION__<<" cppLibObj is nullptr!";
        return -1;
    }

    qInfo() <<__FUNCTION__<< "cppLibObj->TestAddFunc(1, 2)="<< cppLibObj->TestAddFunc(1, 2);

注意这里需要包含纯虚类TestPlugin定义所在的头文件。

三、运行结果如下:

相关推荐
何曾参静谧10 分钟前
「QT」文件类 之 QTextStream 文本流类
开发语言·qt
liyuanbhu14 分钟前
Halcon HImage 与 Qt QImage 的相互转换(修订版)
qt·计算机视觉·halcon
可均可可38 分钟前
C++之OpenCV入门到提高005:005 图像操作
c++·图像处理·opencv·图像操作
zyx没烦恼42 分钟前
【STL】set,multiset,map,multimap的介绍以及使用
开发语言·c++
机器视觉知识推荐、就业指导1 小时前
基于Qt/C++与OpenCV库 实现基于海康相机的图像采集和显示系统(工程源码可联系博主索要)
c++·qt·opencv
机器视觉知识推荐、就业指导1 小时前
使用 Qt 实现基于海康相机的图像采集和显示系统(不使用外部视觉库,如Halcon\OpenCv)[工程源码联系博主索要]
数码相机·qt
myloveasuka2 小时前
类与对象(1)
开发语言·c++
ROC_bird..3 小时前
STL - vector的使用和模拟实现
开发语言·c++
机器视觉知识推荐、就业指导3 小时前
C++中的栈(Stack)和堆(Heap)
c++
Mr_Xuhhh5 小时前
递归搜索与回溯算法
c语言·开发语言·c++·算法·github