Linux+qt:创建动态库so,以及如何使用(详细步骤)_linux qt 生成动态库

3、给动态库添加一个对外开放的接口文件

例如:添加一个testApi的文件,想向外面暴露哪些接口,可以在这里表示

(1)头文件

#ifndef TESTAPI_H
#define TESTAPI_H

#include <QString>
using namespace std;

//定义宏
#if defined(__cplusplus)
#define D_EXTERN_C extern "C"
#else
#define D_EXTERN_C
#endif

#define D_CALLTYPE
#define D_DECL_EXPORT   __attribute__((visibility("default")))
#define D_DECL_IMPORT   __attribute__((visibility("default")))


//向外暴露2个接口
D_EXTERN_C QString D_CALLTYPE printfAppPath();

D_EXTERN_C QString D_CALLTYPE printfCurrentPath();

#endif // TESTAPI_H

(2)源文件

具体实现,可以在TestDll中进行功能的是实现。

#include "testapi.h"
#include "testdll.h"

QString printfAppPath()
{
    return TestDll::getInstance()->printfAppPath();
}

QString printfCurrentPath()
{
    return TestDll::getInstance()->printfCurrentPath();
}

4、了解下Qt的 .pri文件(非常实用)

(1).pri文件功能:把额外用到的一些自定义组件放在一个文件中,方便调用,使用的时候采用include引用即可。

(2)具体创建流程:

**1)**打开项目文件夹,在这里面新建一个文件夹(名为demo);

**2)**在demo文件夹下新建一个pri文件(名为demo)。(怎么新建?可以新建一个文本文件,然后重命名为demo.pri);

**3)**打开Qt Creator ,在你的项目的Pro文件中加入相关的 .pri文件

写完保存后,自动刷新,.pri文件会自动导入到你的工程下。

include(General/general.pri)

INCLUDEPATH += -I $$PWD/General

**4)**然后可以在demo文件中添加Headers,Sources,Resources等文件~,如此一来下次使用就直接引用这个demo文件的内容即可。

HEADERS += \
    P W D / T i m e r M a n a g e r . h     PWD/TimerManager.h \     PWD/TimerManager.h   PWD/Singleton.h

SOURCES += \
    $$PWD/TimerManager.cpp

5、如何调用动态库.so

(1)在调用的地方进行,动态库接口声明:

//动态库接口声明
typedef QString (*TYPE_printfAppPath)();
typedef QString (*TYPE_printfCurrentPath)();


// 声明一个变量
TYPE_printfAppPath          printfAppPath;
TYPE_printfCurrentPath      printfCurrentPath;


//加载动态库
bool loadLibrary(const QString& appPath);

(3)源文件:

实现加载动态库,以及如何使用这个接口。

bool loadLibrary(const QString& appPath)
{
    QLibrary *m_pLibTest;
    
    //按照实际动态库所在的目录
    QString strLibFile = appPath + "/dll/libtestDll.so";

    if (QFile::exists(strLibFile))
        m_pLibTest = new QLibrary(strLibFile);
    else {
        slotAppendText(strLibFile + " don't exists");
        return false;
    }

    if(!m_pLibTest->load())
    {
        QString strErrMsg = m_pLibTest->errorString();
        slotAppendText(strLibFile + " load failed: " + m_pLibTest->errorString());
        return false;
    }
    else
    {
        slotAppendText(strLibFile + " load success");
    }


    printfAppPath    = reinterpret_cast<TYPE_printfAppPath>(m_pLibTest->resolve("printfAppPath"));
    printfCurrentPath    = reinterpret_cast<TYPE_printfCurrentPath>(m_pLibTest->resolve("printfCurrentPath"));


    if(!printfAppPath)
    {
        slotAppendText("printfAppPath not resolve");
        return false;
    }

    if(!printfCurrentPath)
    {
        slotAppendText("printfCurrentPath not resolve");
        return false;
    }

    QString strAppPath = printfAppPath();
    QString strCurrentPath = printfCurrentPath();

    slotAppendText("strAppPath : " + strAppPath);
    slotAppendText("strCurrentPath : " + strCurrentPath);

    return true;

}
Linux中,Qt Creator是一个强大的集成开发环境,用于开发跨平台的应用程序。在使用Qt Creator创建和调用动态库时,需要经过以下几个步骤: 1. 首先,在Qt Creator中新建一个工程。选择“Dynamic Library”作为项目类型。 2. 在工程文件中,定义需要暴露给其他程序使用的函数和类。可以在.h头文件中声明函数和类的接口,并在.cpp源文件中实现相应的功能。 3. 编译生成动态库文件。在Qt Creator中,可以点击“构建”按钮编译和链接生成动态库文件。生成动态库文件一般以.so(shared object)为扩展名。 4. 创建一个新的可执行程序项目,并引用该动态库。在新的项目中,需要在.pro文件中添加对动态库的依赖关系。例如,可以使用LIBS += -L/path/to/library -lmylibrary来指定动态库的路径和名称。 5. 在可执行程序中调用动态库中的函数或类。在主函数或其他需要使用动态库的地方,可以直接调用动态库中定义的函数或类,实现相应的功能。 值得注意的是,动态库的调用中还需要注意以下几点: 1. 在调用动态库函数时,需要先加载动态库。可以使用dlopen函数加载动态库文件,并使用dlsym函数获取需要调用的函数指针。 2. 调用动态库中的函数时,需要根据函数的参数类型进行适当的类型转换。因为动态库函数的参数类型可能与调用者的类型不完全匹配。 3. 在完成动态库使用后,需要使用dlclose函数关闭对动态库的引用,释放相关资源。 总结来说,使用Qt Creator在Linux创建和调用动态库需要进行项目的设置、编译生成动态库文件,然后在其他项目中引用动态库并调用其中定义的函数或类。同时,还需要注意动态库的加载和关闭过程,以确保正确使用动态库功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值