QLibrary* 加载动态库文件 (**)

Qt:QLibrary简析与使用

QLibrary* 加载动态库文件 (**)

-----------------------------------------------------------------------

QLibrary* 无需与 app源代码一起编译,就可以直接使用库了???

=========================================

QLibrary* 加载动态库文件 (**)

Qt:QLibrary简析与使用

文档摘要:

QLibrary用于动态加载dll,其实例在单个共享对象文件(我们称之为“库”,但也称为“DLL”)上运行,以独立于平台的方式提供对库中功能接口的访问。

使用时应调用load()来加载动态库文件,isLoaded()用于检查加载是否成功,resolve()用于解析库中的符号。如果库尚未加载,resolve()函数会隐式地尝试加载它。

QLibrary的多个实例可用于访问同一物理库。

加载后,库将保留在内存中,直到应用程序终止。您可以尝试使用unload()卸载库,但是如果QLibrary的其他实例正在使用同一个库,则卸载库将失败,并且只有在每个实例都调用unload()时才会发生卸载。

QLibrary的一个典型用法是解析库中导出的符号,并调用该符号表示的C函数。这被称为“显式链接”,与“隐式链接”不同,隐式链接是在构建过程中链接可执行文件与库时通过链接步骤完成的。

简单的例子:

main.cpp

    QLibrary* mainFunDll = new QLibrary(filename);//加载指定路径的.dll
    if (mainFunDll->load()) //若加载成功
    {
        getObj obj = (getObj)mainFunDll->resolve("getDllObj");//取出该符号
        APPAPI* mF = obj();//调用接口
    }
    //mF即为从dll导出的类对象

.dll模块中的.cpp

MAINFUNC_EXPORT APPAPI* getDllObj() {
    return new QtClassLibrary;//返回dll中的类对象,main.cpp中即可进行相应操作。
}

————————————————
版权声明:本文为CSDN博主「gigi怪」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_45482816/article/details/113648676

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值