使用def文件从dll导出
模块定义 (.def) 文件是包含一个或多个描述 DLL 各种属性的 Module 语句的文本文件。如果不使用 __declspec(dllexport) 关键字导出 DLL 的函数,则 DLL 需要 .def 文件。
.def 文件必须至少包含下列模块定义语句:
文件中的第一个语句必须是 LIBRARY 语句。此语句将 .def 文件标识为属于 DLL。LIBRARY 语句的后面是 DLL工程的名称。链接器将此名称放到 DLL 的导入库中。
EXPORTS 语句列出名称,可能的话还会列出 DLL 导出函数的序号值。通过在函数名的后面加上 @ 符和一个数字,给函数分配序号值。当指定序号值时,序号值的范围必须是从 1 到 N,其中 N 是 DLL 导出函数的个数。
.def 文件中的注释由每个注释行开始处的分号 (;) 指定,且注释不能与语句共享一行。
创建新的动态链接库DLL项目
1.创建静态项目MathFucsDll
选择 win32项目-->输入MathFuncsDll项目名称->下一步->选择DLL;选择附加选项的空项目->完毕。(或者不选选择附加选项的空项目也行,就是默认)
2.创建库函数
[cpp]
//MyMathFuncs.cpp
int nDataBase=1;//全局变量
int Add(int a,int b)
{
return (a+b)*nDataBase;
}
int _stdcall Sub(int a,int b)
{
return (a-b)*nDataBase;
}
int _cdecl Multiply(int a,int b)
{
return a*b;
}
3.创建def文件
[cpp]
//MyMathFuncs.def
//LIBRARY和EXPORTS不可以小写,且LIBRARY后面的名称要与工程名相同
;
LIBRARY MathFuncsDll
EXPORTS
Add @3
Sub @5
Multiply @1
nDataBase DATA
;nDataBase全局变量,只写 (nDataBase);(nDataBase data);(nDataBase @2)都行
创建引用动态链接库的应用程序
1.创建引用动态链接库的控制台应用程序:
在同一个解决方案中添加项目MyExecRefsDll:选择 win32控制台应用程序->输入MyExecRefsDll项目名称->下一步->选择控制台应用程序;选择附加选项的空项目->完毕
2.在应用程序中使用动态链接库的功能
项目,引用->通用属性->框架和引用->添加引用->会出现MathFuncsDll的项目名称和项目目录->确定 (最简单的一种)
或者是,添加库目录及附加库:项目,属性->连接器->常规->附加库目录:如$(OutDir)
项目,属性->连接器->输入->附加依赖项:MathFuncsDll.lib;或者是在代码中添加:#pragma comment(lib,"MathFuncsDll.lib")
且MathFuncsDll.dll必须与MyExecRefsDll.exe文件在同一个目录
3.程序
[cpp]
#include "stdafx.h"
#include <iostream>
using namespace std;
extern int _declspec(dllimport) nDataBase;//引用dll中的全局变量
//声明函数,需与Dll中的函数定义一致(包括其函数调用修饰词)
int Add(int a,int b);
int _stdcall Sub(int a,int b);
int _cdecl Multiply(int a,int b);
int _tmain(int argc, _TCHAR* argv[])
{
nDataBase=2;
cout<<Add(1,2)<<endl;//6
cout<<Sub(3,4)<<endl;//-2
cout<<Multiply(4,5)<<endl;//20
return 0;
}
比较使用_declspec(dllexport)与使用.def文件来导出Dll函数的异同
相同:创建项目和引用动态库相同
不同:
定义时:.def的要有其文件(LIBRARY EXPORTS),而另外一种则需要在其函数前添加_declspec(dllexport)
使用时:.def使用函数前要有函数声明,而使用_declspec(dllexport)的要添加头文件
补充:软件开发 , C++ ,