C++开发基础之创建DLL的常见的6种导出函数(Export Functions)形式

前言

在 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;
}

参考文档

c++创建dll导出函数名称

  • 9
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

dotnet研习社

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值