c++如何调用dll中的函数_C++动态链接库函数调用方法

隐式链接通过.lib文件在程序启动时自动加载DLL,需提供.dll、.lib和.h文件,使用#pragma comment(lib)链接库并直接调用函数;显式链接则在运行时用LoadLibrary、GetProcAddress和FreeLibrary动态加载和调用函数,灵活性高,适合按需加载;注意使用__declspec(dllexport)导出函数,加extern "C"避免C++命名修饰,确保DLL路径正确。

在C++中调用DLL中的函数,主要有两种方式:隐式链接(通过.lib文件)和显式链接(使用Windows API动态加载)。下面分别介绍这两种方法的实现步骤和注意事项。

1. 隐式链接(静态加载)

隐式链接是在程序启动时自动加载DLL,需要以下三个文件:

  • DLL 文件(.dll)——运行时必须存在
  • 导入库文件(.lib)——编译链接时使用
  • 头文件(.h)——声明DLL中导出的函数

步骤如下:

  1. 将DLL和对应的.lib文件添加到项目目录或链接器能访问的路径
  2. 在代码中包含DLL提供的头文件
  3. 在项目设置中链接.lib文件(可在代码中用#pragma comment(lib, "xxx.lib"))
示例代码:
#include "MyDll.h"  // 包含函数声明

#pragma comment(lib, "MyDll.lib")

int main() {
    MyExportedFunction();  // 直接调用DLL函数
    return 0;
}

这种方式调用简单,但要求DLL在程序启动时就存在,否则程序无法加载。

2. 显式链接(动态加载)

显式链接使用Windows API在运行时手动加载DLL,灵活性更高,适合按需加载或处理DLL缺失的情况。

关键API函数:

  • LoadLibraryLoadLibraryEx:加载DLL
  • GetProcAddress:获取函数地址
  • FreeLibrary:释放DLL
示例代码:
#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不存在或函数未导出的情况,程序更健壮。

3. 注意事项与常见问题

确保DLL正确导出函数。在DLL源码中需使用__declspec(dllexport)导出函数,例如:

// DLL中定义
extern "C" __declspec(dllexport) void MyExportedFunction() {
    // 函数实现
}

使用extern "C"可避免C++命名修饰(mangling),便于调用。若不加,显式链接时需使用修饰后的函数名(可用dumpbin /exports查看)。

调试时若提示“找不到DLL”,请确认DLL位于可执行文件同目录、系统路径或已设置环境变量。

基本上就这些。根据项目需求选择合适的方式,隐式链接方便,显式链接灵活。