

新闻资讯
技术学院Windows下C++调用DLL有隐式链接和显式链接两种方式:前者编译时绑定,需DLL、.lib和头文件,调用简单但路径固定;后者运行时用LoadLibrary/GetProcAddress加载,灵活适用于插件等场景,需注意名称修饰、路径、位数匹配等问题。
在 Windows 下用 C++ 调用 DLL,主要有两种方式:隐式链接(静态链接导入)和显式链接(运行时加载)。区别在于链接时机和灵活性——隐式链接编译时就绑定 DLL,简单但依赖固定路径;显式链接在运行时用 LoadLibrary 和 GetProcAddress 手动加载,更灵活,适合插件机制或避免启动失败。
隐式链接需要三样东西:DLL 文件、对应 .lib 导入库
(由 DLL 生成)、以及头文件(声明导出函数)。编译器靠 .lib 知道函数签名和符号名,链接器在生成 EXE 时写入导入表,系统启动时自动加载 DLL。
__declspec(dllexport) 或 .def 文件)#include 对应头文件,并链接 .lib(如 project.lib)例如:int result = MyAdd(3, 5); —— 只要头文件里声明了 MyAdd,且链接了 mylib.lib,就能工作。
显式链接不依赖 .lib,完全靠 Win32 API 在运行时操作。适合需要按需加载、容错处理(比如 DLL 缺失时友好提示)、或多版本共存的场景。
HMODULE hLib = LoadLibrary(L"mylib.dll"); 加载 DLL(注意宽字符)NULL 表示失败,可用 GetLastError() 查原因GetProcAddress(hLib, "MyAdd") 获取函数地址,强转为对应函数指针类型FreeLibrary(hLib) 卸载小技巧:函数指针类型建议用 typedef 或 using 定义,比如 using AddFunc = int(*)(int, int);,让代码更清晰安全。
C++ 编译器会对函数名做修饰(比如加参数类型信息),导致 GetProcAddress 找不到原始名字。解决方法有二:
extern "C" 包裹导出函数声明,禁用 C++ 名字修饰(推荐用于 C 风格接口)验证导出名是否正确?可用 dumpbin /exports mylib.dll(VS 工具)或 Dependency Walker 查看实际导出符号。
很多初学者卡在“找不到 DLL”或“找不到过程入口”,其实多数是路径或符号问题:
Dependencies.exe(现代版 Dependency Walker)查看 DLL 是否还缺其他依赖项LoadLibrary 推荐用 LoadLibraryW + L"xxx.dll",避免多字节编码陷阱写个简单的封装类或 RAII 封装 HMODULE,能显著减少资源泄漏和重复判断。