详解 Qt 调用 DLL功能函数
来源:互联网 发布:淘宝网蒸锅小片毕链 编辑:程序博客网 时间:2024/05/16 00:55
AD:
Qt 调用 DLL功能函数是本文要介绍的内容,DLL 是一个包含可由多个程序同时使用的代码和数据的库。不说这么多,先来看内容。
声明:事先我已经自己动手写了一个简单的DLL文件(myDLL.dll),C版接口的。并且用我前两篇有关DLL文章里面的方法,从DLL中导出了导入库(.lib)文件,dll中有两个函数,原型如下:
- void
HelloWorld(); //函数内部调用Win32 API,功能是弹出一个helloworld提示框 - int
add(int a,int b); //实现两个数相加,并返回结果
下面分别通过显示调用和隐式调用两种方法,来模拟Qt如何调用外部dll文件中的功能函数,follow me....
预备知识:
1、如果在没有导入库文件(.lib),而只有头文件(.h)与动态链接库(.dll)时,我们才需要显示调用,如果这三个文件都全的话,我们就可以使用简单方便的隐式调用。
2、通常Windows下程序显示调用dll的步骤分为三步(三个函数):LoadLibrary()、GetProcAdress()、FreeLibrary()
其中,LoadLibrary() 函数用来载入指定的dll文件,加载到调用程序的内存中(DLL没有自己的内存!)
GetProcAddress() 函数检索指定的动态链接库(DLL)中的输出库函数地址,以备调用
FreeLibrary() 释放dll所占空间
1、显示调用
Qt提供了一个 QLibrary 类供显示调用。下面给出一个完整的例子:
- #include
<QApplication> - #include
<QLibrary> - #include
<QDebug> - #include
<QMessageBox> - #include
"dll.h" //引入头文件 - typedef
int (*Fun)(int,int); //定义函数指针,以备调用 - int
main(int argc,char **argv) - {
-
QApplication app(argc,argv); -
QLibrary mylib("myDLL.dll"); //声明所用到的dll文件 -
int result; -
if (mylib.load()) //判断是否正确加载 -
{ -
QMessageBox::information(NULL,"OK","DLL load is OK!"); -
Fun //援引 add() 函数 -
if (open) //是否成功连接上 add() 函数 -
{ -
QMessageBox::information(NULL,"OK","Link to Function is OK!"); -
//这里函数指针调用dll中的 add() 函数 -
qDebug() -
} -
else -
QMessageBox::information(NULL,"NO","Linke to Function is not OK!!!!"); -
} -
else -
QMessageBox::information(NULL,"NO","DLL is not loaded!"); -
return 0; //加载失败则退出
myDLL.dll为自定义的dll文件,将其复制到程序的输出目录下就可以调用。显然,显示调用代码书写量巨大,实在不方便。
2、隐式调用
这个时候我们需要三个文件,头文件(.h)、导入库文件(.lib)、动态链接库(.dll),具体步骤如下:
1、首先我们把 .h 与 .lib/.a 文件复制到程序当前目录下,然后再把dll文件复制到程序的输出目录,
2、下面我们在pro文件中,添加 .lib 文件的位置: LIBS+= -L D:/hitempt/api/ -l myDLL
-L 参数指定 .lib/.a 文件的位置
-l
另外,导入库文件的路径中,反斜杠用的是向右倾斜的
3、在程序中include头文件(我试验用的dll是用C写的,因此要用 extern "C" { #include "dll.h" } )
下面是隐式调用的实例代码:
-
#include <QApplication> -
#include <QDebug> - extern
"C" //由于是C版的dll文件,在C++中引入其头文件要加extern "C" {},注意 - {
-
#include "dll.h" -
} -
int main(int argv ,char **argv) -
{ -
QApplication app(argv,argv); -
HelloWordl(); //调用Win32 API 弹出helloworld对话框 -
qDebug() // dll 中我自己写的一个加法函数 -
return 0; //完成使命后,直接退出,不让它进入事件循环 -
}
还是隐式调用方便啊,直接就可以调用dll中的函数.
小结:详解 Qt 调用 dll 功能函数的内容介绍完了,希望本文对你有所帮助,如果还需要相关资料的话,请参考编辑推荐!
在显式链接下,应用程序必须进行函数调用以在运行时显式加载 DLL。为显式链接到DLL,应用程序必须:
? 调用 LoadLibrary(或相似的函 数)以加载DLL 和获取模块句柄。
? 调用 GetProcAddress,以获取指向应用程序要调用的每个导出函数的函数指针。由于应用程序是通过指针调用DLL 的函数,编译器不生成外部引用,故无需与导入库链接。
? 使用完 DLL 后调用 FreeLibrary。
例如:
typedef UINT (CALLBACK* LPFNDLLFUNC1)(DWORD,UINT);
HINSTANCE hDLL; // Handle to DLL
LPFNDLLFUNC1 lpfnDllFunc1; // Function pointer
DWORD dwParam1;
UINT uParam2, uReturnVal;
hDLL = LoadLibrary(”MyDLL”);
if (hDLL != NULL)
{
}
需要说明的是,typedef UINT (CALLBACK* LPFNDLLFUNC1)(DWORD,UINT);是声明想要调用的函数指针,这个函数的参数必须和DLL里面的一样。DLLFunc1是DLL里面的“实际的函数名”,必须和头文件里面声明的一样,否则将会调用失败。使用需要加Windows.h头文件。Windows里的Qt是用Mingw GCC来编译,而Mingw GCC可以支持Win32的API。使用时并不需要包含头文件。这个方法没有实际验证,理论上是可以的。
Qt调用DLL方法二:使用Qt的API
对于调用DLL的方法,Qt原来本身就有相应的类来实现,用起来和Win32的步骤差不多。下面是代码,已经编译通过。在控制台依次输入qmake –project、qmake、nmake,即可。
#include
#include
#include
//动态链接不需要包含LTM8000D.h头文件
typedef int ( *pcom_open)(int , int , int ); //定义函数指针
int main(int argc, char *argv[])
{
}
Qt调用DLL方法三:直接调用DLL
再在Qt的.pro文件中最后面加上
LIBS += -L. –lxxx
在Qt的源文件中加上
#include “xxx.h”
现在就可以直接调用xxx.h中的函数了。
// xxx.h
#ifndef XXX_H
#define XXX_H
WINAPI int xxx_func(void);
#endif
// main.cpp
#include “xxxh”
#include
#include
int main(int argc, char *argv[])
{
}
总结: 类似于调用DLL的交叉编程使用的场合很多,还可以用Qt生成DLL,给其它工具调用。说到底,VC和Qt等本质上都是一样的,只是提供了不同的C++库。
- 详解 Qt 调用 DLL功能函数
- 详解 Qt 调用 DLL功能函数
- 详解 Qt 调用 DLL功能函数
- Qt调用dll中的功能函数
- Qt调用dll中的功能函数
- Qt调用dll中的功能函数
- Qt调用dll中的功能函数
- Qt调用dll中的功能函数
- Qt调用dll中的功能函数
- Qt调用dll中的功能函数
- Qt调用dll中的功能函数
- Qt调用dll中的功能函数
- Qt调用dll中的功能函数
- Qt调用dll中的功能函数
- Qt调用dll中的功能函数
- Qt调用dll中的功能函数
- Qt调用dll中的功能函数
- Qt调用dll中的功能函数
- 关于使用 class_create,device_create,class_device_create 创建设备节点
- Test
- Linux 性能监测:IO
- Java学习开发知识PDF文档分享,有需要的沉畜猿帮我顶一下
- 招聘启事(Inventor广州售前工程师)
- 详解 Qt 调用 DLL功能函数
- GDB调试release程序
- Android 系统中的六种模式
- #R#简单的抽签
- <c:forEach 的常用整理
- OpenCV学习之图像轮廓提取
- iso-开发基础知识-7-外观模式
- 数据库db2书籍推荐
- POJ 3318 Matrix Multiplication 解题报告 (随机化 & 矩阵性质)