隐式链接通过.lib文件在程序启动时自动加载DLL,需提供.dll、.lib和.h文件,使用#pragma comment(lib)链接库并直接调用函数;显式链接则在运行时用LoadLibrary、GetProcAddress和FreeLibrary动态加载和调用函数,灵活性高,适合按需加载;注意使用__declspec(dllexport)导出函数,加extern "C"避免C++命名修饰,确保DLL路径正确。
在C++中调用DLL中的函数,主要有两种方式:隐式链接(通过.lib文件)和显式链接(使用Windows API动态加载)。下面分别介绍这两种方法的实现步骤和注意事项。
隐式链接是在程序启动时自动加载DLL,需要以下三个文件:
.lib)——编译链接时使用步骤如下:
#include "MyDll.h" // 包含函数声明
#pragma comment(lib, "MyDll.lib")
int main() {
MyExportedFunction(); // 直接调用DLL函数
return 0;
}
这种方式调用简单,但要求DLL在程序启动时就存在,否则程序无法加载。
显式链接使用Windows API在运行时手动加载DLL,灵活性更高,适合按需加载或处理DLL缺失的情况。
关键API函数:
#include#include typedef void (*FuncPtr)(); // 定义函数指针类型 int main() { HMODULE hDll = LoadLibrary(L"MyDll.dll"); // 加载DLL if (!hDll) { std::cout << "无法加载DLL!\n"; return -1; } FuncPtr func = (FuncPtr)GetProcAddress(hDll, "MyExportedFunction"); if (!func) { std::cout << "无法找到函数!\n"; FreeLibrary(hDll); return -1; } func(); // 调用函数 FreeLibrary(hDll); // 释放DLL return 0; }
这种方式可以处理DLL不存在或函数未导出的情况,程序更健壮。
确保DLL正确导出函数。在DLL源码中需使用__declspec(dllexport)导出函数,例如:
// DLL中定义
extern "C" __declspec(dllexport) void MyExportedFunction() {
// 函数实现
}
使用extern "C"可避免C++命名修饰(mangling),便于调用。若不加,显式链接时需使用修饰后的函数名(可用dumpbin /exports查看)。
调试时若提示“找不到DLL”,请确认DLL位于可执行文件同目录、系统路径或已设置环境变量。
基本上就这些。根据项目需求选择合适的方式,隐式链接方便,显式链接灵活。