C++: 模块定义文件声明(.def)的使用

C++: 模块定义文件声明(.def)的使用

分类专栏: C-C++
版权
1. 概念 

dll中有两种导出函数声明的方式:①__declspec(dllexport);②模块定义文件(.def)

其中,.def文件为链接器提供有关被链接程序的导出、属性及其他方面的信息。     

 
                                                      

 2. .def的使用方式
(1).def文件的规则为:
LIBRARY语句:说明.def文件相应的DLL;
EXPORTS语句:在其后要列出导出函数的名称。可以在.def文件中的导出函数名后加@n,表示要导出函数的序号为n(在进行函数调用时,这个序号将发挥其作用);
【注】:.def 文件中的注释由每个注释行开始处的分号 (;) 指定,且注释不能与语句共享一行。

(2)使用

如果想导出 C++ 文件中的函数,则必须将修饰名放到 .def 文件中,或者通过使用外部“C”定义具有标准 C 链接的导出函数。

如果需要将修饰名放到 .def 文件中,则可以通过使用 DUMPBIN 工具或 /MAP 链接器选项来获取修饰名。

请注意,编译器产生的修饰名是编译器特定的。

如果将 Visual C++ 编译器产生的修饰名放到 .def 文件中,则链接到 DLL 的应用程序必须也是用相同版本的 Visual C++ 生成的,这样调用应用程序中的修饰名才能与 DLL 的 .def 文件中的导出名相匹配。

如果生成扩展 DLL 并使用 .def 文件导出,则将下列代码放在包含导出类的头文件的开头和结尾:


#undef AFX_DATA#define AFX_DATA AFX_EXT_DATA// <body of your header file>#undef AFX_DATA#define AFX_DATA这些代码行确保内部使用的 MFC 变量或添加到类的变量是从扩展 DLL 导出(或导入)的。例如,当使用 DECLARE_DYNAMIC 派生类时,该宏扩展以将 CRuntimeClass 成员变量添加到类。省去这四行代码可能会导致不能正确编译或链接 DLL,或在客户端应用程序链接到 DLL 时导致错误。

当生成 DLL 时,链接器使用 .def 文件创建导出 (.exp) 文件和导入库 (.lib) 文件。

然后,链接器使用导出文件生成 DLL 文件。隐式链接到 DLL 的可执行文件在生成时链接到导入库。

参考文章

1. https://blog.csdn.net/sky04/article/details/5410065

2. https://blog.csdn.net/qianpeng4/article/details/76474831

原文地址:https://www.cnblogs.com/guanshan/p/guan2021-6-7_001.html