动态库的创建有两种方法:不使用.def的方法 和 使用.def的方法; 示例: 写个简单的动态库,里面有两个函数,能实现加法减法 s1: 创建一个空动态库dll, 新建头文件sss.h, 在头文件中写入如下代码 s2: 再创建源文件sss.cpp, 如下: s3: 新建模块定义文件Source.def,写入如下内容; s4: 生成动态库DLL; 【注】: 在.def中第一行是数据库的名字, 第二行是固定语句EXPORTS,导出代码, 其他行,add、sub后面可以不加@X; 调用: 1.隐式调用 在同一解决方案下创建空WIN32控制台项目,在源文件中创建main.cpp,其代码如下 注意:隐式调用需要用到动态库里的头文件和动态库文件夹debug里的sss.lib,所以.cpp文件夹中一定要包含,可以拷贝两者到.cpp同一文件夹下,也可以用代码中的方法. 2. 显式调用 在同一解决方案下创建WIN32控制台空项目,在源文件中创建,代码如下 在显式调用中,由于使用的是.def的方法,在获取动态库中函数地址时有两种方法 ①AddFunc ADD1 = (AddFunc)GetProcAddress(hdll,(char*)(1)); 这是在.def文件中add后面加@1的使用方法, 当然你也可以使用通用获取地址方法: ②AddFunc ADD1 = (AddFunc)GetProcAddress(hdll,"add"); AddFunc ADD1 = (AddFunc)GetProcAddress(hdll,(char*)(1));这句(char*)(1)中1是add后面@的数字,相当于add在动态库中的地址,GetProcAddress的函数原型里1这个位置数据类型是char*类型. 附.def的一些小知识: .def 文件中的第一条 LIBRARY 语句不是必须的, 但LIBRARY 语句后面的 DLL 的名称必须正确,即与生成的动态链接库的名称必须匹配。 此语句将 .def 文件标识为属于 DLL。 链接器将此名称放到 DLL 的导入库中。 EXPORTS 语句列出名称,可能的话还会列出 DLL 导出函数的序号值。通过在函数名的后面加上 @ 符和一个数字,给函数分配序号值。当指定序号值时,序号值的范围必须是从 1 到 N,其中 N 是 DLL 导出函数的个数。 LIBRARY BTREE EXPORTS Insert @1 Delete @2 Member @3 Min @4 “def 文件中的注释由每个注释行开始处的分号 (;) 指定。 注释不能与语句共享一行,但可以在多行语句的规范间出现。 参考文章 1. https://blog.csdn.net/qq_37059136/article/details/80167388