前言
在 C++ 中,导出函数(Export Functions)通常是为了创建动态链接库(DLL)或共享库,以便其他程序或模块可以调用这些函数。导出函数的形式主要取决于编译器和平台,以下是几种常见的导出函数的方式:
导出方式
1. __declspec(dllexport)
- 平台: Windows
- 编译器: Visual C++ 编译器
C++ 导出函数声明和定义:
// YourLibrary.h
#ifdef YOURLIBRARY_EXPORTS
#define YOURLIBRARY_API __declspec(dllexport)
#else
#define YOURLIBRARY_API __declspec(dllimport)
#endif
extern "C" YOURLIBRARY_API int Add(int a, int b);
C++ 导出函数定义:
// YourLibrary.cpp
#include "YourLibrary.h"
int Add(int a, int b) {
return a + b;
}
2. __attribute__((visibility("default")))
- 平台: Linux
- 编译器: GCC 编译器
C++ 导出函数声明和定义:
// YourLibrary.h
#ifndef YOURLIBRARY_H
#define YOURLIBRARY_H
__attribute__((visibility("default"))) int Add(int a, int b);
#endif // YOURLIBRARY_H
C++ 导出函数定义:
// YourLibrary.cpp
#include "YourLibrary.h"
int Add(int a, int b) {
return a + b;
}
```
3. extern "C"
- 平台: 通用
- 说明: 用于确保按照C语言的命名规范导出,避免C++名称修饰。
C++ 导出函数声明和定义:
// YourLibrary.h
#ifndef YOURLIBRARY_H
#define YOURLIBRARY_H
extern "C" int Add(int a, int b);
#endif // YOURLIBRARY_H
C++ 导出函数定义:
// YourLibrary.cpp
#include "YourLibrary.h"
int Add(int a, int b) {
return a + b;
}
```
4. #pragma comment(lib, "YourLibrary.lib")
- 平台: Windows
- 说明: 使用
#pragma
指令告诉编译器链接对应的库文件。
这个用法通常在头文件中不涉及。
cpp #pragma comment(lib, "YourLibrary.lib")
5. Module Definition (.def) 文件:
- 平台: 通用
- 说明: 使用 .def 文件定义导出函数。
6. __declspec(dllexport)
函数声明和定义分开:
- 平台: Windows
- 说明: 将函数声明和定义分开,使用 __declspec(dllexport) 修饰定义。
这个用法通常在头文件中不涉及。
C++ 导出函数声明:
// YourLibrary.h
#ifndef YOURLIBRARY_H
#define YOURLIBRARY_H
extern "C" int __declspec(dllexport) Add(int a, int b);
#endif // YOURLIBRARY_H
C++ 导出函数定义:
// YourLibrary.cpp
#include "YourLibrary.h"
int Add(int a, int b) {
return a + b;
}