动态加载共享库需按平台使用dlopen/dlsym或LoadLibrary/GetProcAddress,通过extern "C"导出函数避免命名修饰,封装跨平台接口可提升代码复用性,完整流程包括加载库、获取函数指针、调用及释放资源。

在C++中动态加载和使用共享库(Linux下的.so文件或Windows下的DLL)是一种常见的运行时模块化编程技术。它允许程序在运行时按需加载库并调用其中的函数,适用于插件系统、热更新等场景。
动态加载的核心是通过操作系统提供的API来打开库文件、获取函数地址,并在使用完毕后释放资源。不同平台的接口不同:
为了跨平台兼容,通常会使用宏定义封装这些差异。
假设有一个名为 libmathplugin.so 的共享库,导出一个函数:
立即学习“C++免费学习笔记(深入)”;
// mathfunc.h extern "C" double add(double a, double b);
在主程序中动态加载该库:
#include <dlfcn.h>
#include <iostream>
<p>int main() {
void* handle = dlopen("./libmathplugin.so", RTLD_LAZY);
if (!handle) {
std::cerr << "无法加载库: " << dlerror() << '\n';
return 1;
}</p><pre class="brush:php;toolbar:false;"><pre class="brush:php;toolbar:false;">// 获取函数指针
using AddFunc = double(*)(double, double);
AddFunc add_func = (AddFunc)dlsym(handle, "add");
const char* error = dlerror();
if (error) {
std::cerr << "无法找到函数: " << error << '\n';
dlclose(handle);
return 1;
}
// 调用函数
std::cout << "结果: " << add_func(3.5, 2.5) << '\n';
dlclose(handle);
return 0;}
编译时需要链接 dl 库:
g++ main.cpp -ldl
对于DLL,假设导出了相同的 add 函数:
// DLL中的导出声明(mathfunc.h) extern "C" __declspec(dllexport) double add(double a, double b);
主程序加载DLL:
#include <windows.h>
#include <iostream>
<p>int main() {
HMODULE handle = LoadLibrary(L"mathplugin.dll");
if (!handle) {
std::cerr << "无法加载DLL\n";
return 1;
}</p><pre class="brush:php;toolbar:false;"><pre class="brush:php;toolbar:false;">using AddFunc = double(*)(double, double);
AddFunc add_func = (AddFunc)GetProcAddress(handle, "add");
if (!add_func) {
std::cerr << "无法找到函数\n";
FreeLibrary(handle);
return 1;
}
std::cout << "结果: " << add_func(3.5, 2.5) << '\n';
FreeLibrary(handle);
return 0;}
可以定义统一接口简化使用:
#ifdef _WIN32
#include <windows.h>
using LibHandle = HMODULE;
#define load_lib(name) LoadLibraryA(name)
#define get_func(lib, func) GetProcAddress(lib, func)
#define free_lib(lib) FreeLibrary(lib)
#else
#include <dlfcn.h>
using LibHandle = void*;
#define load_lib(name) dlopen(name, RTLD_LAZY)
#define get_func(lib, func) dlsym(lib, func)
#define free_lib(lib) dlclose(lib)
#endif
这样主逻辑可保持一致:
LibHandle handle = load_lib("myplugin.dll");
if (handle) {
auto func = (FuncType)get_func(handle, "function_name");
if (func) func();
free_lib(handle);
}
基本上就这些。关键是确保函数以 extern "C" 导出避免C++命名修饰,同时注意路径、权限和错误处理。实际项目中还可结合配置文件或插件注册机制实现更灵活的加载策略。
以上就是c++++中如何动态加载和使用so/dll库_c++动态库加载与调用函数方法的详细内容,更多请关注php中文网其它相关文章!
.dll文件缺失怎么办?.dll文件在哪下载?不用担心,这里为大家提供了所有的.dll文件下载,无论用户丢失的是什么.dll文件,在这里都能找到。用户保存后,在网盘搜索dll文件全称即可查找下载!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号