使用__declspec(dllexport)可导出DLL函数,配合extern "C"避免名称修饰,通过条件宏区分导出与导入,生成.dll和.lib文件供调用程序链接使用。

在C++中编写DLL(动态链接库)并导出函数,常用的方法是使用 __declspec(dllexport) 关键字。它告诉编译器将指定的函数、类或变量从DLL中导出,供其他程序或模块调用。下面详细介绍如何创建一个简单的DLL并正确导出函数。
1. 创建DLL项目
在Visual Studio中新建一个“动态链接库(DLL)”项目,或者手动创建源文件和头文件。基本结构包括:
- dllmain.cpp(可选,用于DLL初始化)
- myfunction.h(函数声明头文件)
- myfunction.cpp(函数实现文件)
2. 使用 __declspec(dllexport) 导出函数
在函数定义前加上 __declspec(dllexport),即可将其导出。例如:
// myfunction.h#pragma once
#ifdef __cplusplus
extern "C" {
#endif
// 声明导出函数
__declspec(dllexport) int add(int a, int b);
__declspec(dllexport) void sayHello();
#ifdef __cplusplus
}
#endif
// myfunction.cpp
#include iostream>
using namespace std;
// 实现函数
int add(int a, int b) {
return a + b;
}
void sayHello() {
cout }
注意:如果函数名包含C++命名修饰(name mangling),在外部调用时可能难以识别。使用 extern "C" 可避免名称修饰,使函数更易于被C或其他语言调用。
立即学习“C++免费学习笔记(深入)”;
3. 编译生成DLL
编译项目后,会生成两个关键文件:
- .dll 文件:运行时调用的动态库
- .lib 文件:导入库,用于在调用方链接时解析符号
4. 在其他程序中使用DLL
要使用DLL中的函数,需在调用程序中引入头文件和.lib文件,并确保.dll位于可执行文件路径下。
// main.cpp#include "myfunction.h"
int main() {
cout sayHello();
return 0;
}
链接时需将生成的 .lib 添加到项目依赖项中,或使用 #pragma comment(lib, "yourlib.lib") 自动链接。
5. 条件宏简化导出/导入
在实际开发中,通常使用宏来区分导出(DLL内部)和导入(外部使用):
// mydll.h#pragma once
#ifdef MYDLL_EXPORTS
#define MYAPI __declspec(dllexport)
#else
#define MYAPI __declspec(dllimport)
#endif
extern "C" {
MYAPI int add(int a, int b);
MYAPI void sayHello();
}
在DLL项目中定义预处理器宏 MYDLL_EXPORTS,这样编译DLL时函数会被导出;外部程序包含该头文件时则自动使用 dllimport,提高调用效率。
基本上就这些。掌握 __declspec(dllexport) 和 extern "C" 的配合使用,就能高效地编写和调用C++ DLL。不复杂但容易忽略细节,比如名称修饰和链接方式。











