使用VS2017建立DLL并连接至其余项目中【转】

  1. 启动VS2017,点击菜单栏上的“文件->新建->项目”建立一个新的开发项目;
    这里写图片描述
  2. 在弹出的“新建项目窗口”中,选择左侧“Visual C++”列表下的“Windows桌面”,而后选择右侧的项目类型为“动态连接库(DLL)”,接着设置项目名称和存储位置以及解决方案名称。配置完毕后,点击“肯定按钮”肯定建立动态连接库项目;
    这里写图片描述
    该步骤以后,文件夹中生成DLL1文件夹,包含以下内容
    这里写图片描述
  3. 项目建立以后,点击VS2017界面菜单栏上的“生成 > 生成解决方案”编译新建立的项目代码,确认是否存在问题(极少会出现问题);
    这里写图片描述
    生成解决方案后,会在Debug文件夹中生成以下文件
    这里写图片描述
  4. 编译结束以后,能够在VS2017的输出窗口中见到编译成功的输出信息;
    这里写图片描述
  5. 在VS2017开发界面中,右键单击“解决方案”里面“Dll1”项目下的“头文件”目录,在弹出菜单中选择“添加 > 新建项”;
    这里写图片描述
  6. 在弹出的“添加新项”对话框中,选择“头文件(.h)”,而后输入头文件的名称“dll1.h”,以后点击“添加按钮”肯定添加一个名为“dll1.h”的头文件;
    这里写图片描述
    相应文件中多处dll1.h头文件
    这里写图片描述
  7. 在Windows中,定义在dll中的变量、函数和类,若是但愿让别的程序可以访问。必须经过manifest文件指定导出目标(变量、函数或类)或者经过_declspec(dllimport)关键字指定须要导出的目标,而后在使用dll的程序中经过_declspec(dllimport)关键字指定导入的目标。在开发中使用_declspec()定义导出/导入目标是最方便的作法,所以,能够继续向“dll1项目”中添加一个头文件 “export.h”,而后添加自适应导出/导入目标的宏;(图中第一个应该为_declspec(dllimport)第二个为_declspec(dllexport),存在图中错误)
    这里写图片描述
    文件中反应出来的是,在以下目录下生成export.h文件
    这里写图片描述
  8. 鼠标选中DLL1项目右键“ 属性”,打开Dll1项目的属性页窗口;
    这里写图片描述
  9. 在弹出的“Dll1属性页窗口”中,将配置设置为”全部配置”,而后选中“C/C++ > 预处理器”,接着在“预处理器定义”右侧的属性值中增长“EXPORT_DLL”。设置完毕后,点击“肯定按钮”肯定属性设置;
    这里写图片描述
  10. 在属性页中定义了EXPORT_DLL宏以后,export.h文件中EXPORT_API宏对应的值就变成了__declspec(dllexport),对于Dll1项目而言,只要使用EXPORT_API修饰的对象,都将变成导出目标。相对而言,在引用Dll1的另外一项目中,默认是没有定义EXPORT_DLL宏的,那么用EXPORT_API修饰的对象,则都是导入目标;
    这里写图片描述
  11. 打开 “dll1.h”文件,使用#include包含“export.h”头文件,而后使用EXPORT_API声明一个名为printHello()的DLL导出函数;
    这里写图片描述
  12. 打开“Dll1.cpp”,包含“stdio.h”头文件并写入printHello()函数的实现;
    这里写图片描述
  13. 生成解决方案(F7),能够在输出窗口中见到全部代码均编译成功;
    这里写图片描述
    相应的在Debug文件夹下,多处以下几个文件
    这里写图片描述
  14. 右键单击左侧列表中“解决方案”,而后在弹出菜单中选择“添加 > 新建项目”,向解决方案中添加一个新的控制台项目,用于测试Dll1中导出的printHello()函数是否能够正常访问;
    这里写图片描述
  15. 在弹出的“添加新项目窗口”中,选择“Windows桌面 > Windows控制台应用程序”,而后输入新项目的名称并点击“肯定按钮”建立新项目;
    这里写图片描述
    相应文件中表现以下
    这里写图片描述
    包含文件以下
    这里写图片描述
  16. 右键单击“解决方案”列表中新建立的控制台项目,在弹出菜单中选择“设置为启动项目”,将控制台项目设置为启动项目。这样,每当运行程序时,启动的就是这个新建立的控制台项目(DLL项目是没法独立运行的);
    这里写图片描述
  17. 点击VS2017界面中的“本地Windows调试器”按钮,编译并运行控制台项目,会发现有一个黑屏幕一闪而过。这是因为控制台程序在执行完main()函数后,直接退出了(DevCPP中则会自动暂停,防止控制台直接退出)。
    这里写图片描述
    文件中反应以下
    这里写图片描述
  18. 为了让控制台程序执行完毕后依然保持开启状态,能够打开 ConsoleApplication1.cpp文件,而后包含stdlib.h文件并在main()函数体的return语句之上添加程序暂停语句”system(“pause”);”
    这里写图片描述
  19. 写好代码以后,再次调试运行程序,能够见到控制出现并暂停。在控制台窗口中,点任意键能够退出控制台程序;
    这里写图片描述
  20. 回到VS2017开发界面,右键单击“解决方案管理器”列表中的控制台项目,在弹出菜单中选择“生成依赖项 > 项目依赖项”打开“项目依赖项窗口”;
    这里写图片描述
  21. 在弹出的“项目依赖项窗口”中,勾选依赖于“Dll1”,表示控制台项目ConsoleApplication1依赖Dll1项目。这样能够保证每次编译ConsoleApplication1时,编译器总会自动先编译Dll1项目,保证Dll1老是最新的。设置完毕后,点击“肯定按钮”关闭“项目依赖项窗口”;
    这里写图片描述
  22. 右键单击VS2017工做区中的“Dll1.cpp选项卡页”,在弹出菜单中选择“打开所在的文件夹”;
    这里写图片描述
  23. 在打开的Dll1.cpp文件所在的文件夹中,点击返回按钮,从新进入到Dll1项目的Debug输出目录中。在该目录中能够见到Dll1项目生成的符号连接库“Dll1.lib”和动态连接库“Dll1.dll”。 若是须要在另外一个项目中加载“Dll1.dll”文件,那么经过连接“Dll1.lib”是最简便的方式(不然就要经过LoadLibrary()及相关函数经过代码加载动态库了);
    这里写图片描述
  24. 返回VS2017开发界面中,右键单击“解决方案列表”中的ConsoleApplication1,在弹出菜单中,选择“属性页”,打开控制台项目的属性页;
    这里写图片描述
  25. 在弹出的ConsoleApplication1属性页窗口中,将配置设置为“全部配置”,而后在左侧“配置属性”列表中,选择“连接器 > 常规”,接着在右侧属性列表中选择“附加库目录”属性右方的编辑框,在弹出的下拉列表中选择“编辑”;
    这里写图片描述
  26. 在弹出的“附加库目录窗口“中,点击”宏(M) >>“按钮,展开VS2017的宏列表;
    这里写图片描述
  27. 在展开的VS2017宏列表中,搜索“(Out(Out”便可看到列表中显示宏“(OutDir)”表示解决方案Dll1的输出目录。因为ConsoleApplication1和Dll1项目均位于解决方案Dll1下,所以在默认配置下,这两个项目的输出文件均位于该输出目录下。只要将$(OutDir)充当静态库的查找目录,就能够方便的找到“Dll1.lib”。记住这个宏名称后,点击“宏(M) <<”按钮隐藏宏列表页;
    这里写图片描述
  28. 返回“附加库目录窗口”中,点击“新建文件夹图标”,而后在新出现的附加目录项中填入“$(OutDir)”并点击”肯定按钮”结束附加库设置;
    这里写图片描述
  29. 附加库设置完毕后,能够在项目属性页中见到“附加库目录”属性右方已经被填入了设置的值;
    这里写图片描述
  30. 选择“ConsoleApplication1属性页”左侧列表中的“输入”,而后在右侧“附加依赖项”中填入“dll1.lib;”,告诉编译器须要连接dll1.lib,进而加载咱们须要的“Dll1.dll”。设置以后,点击“肯定按钮”关闭属性页;
    这里写图片描述
  31. 在VS2017工做区中,打开“ConsoleApplication1.cpp”文件,而后在代码中包含“dll1.h”(注意这里的相对路径,目录起点为ConsoleApplication1.cpp所在的目录),以后在main()函数中添加调用printHello()函数的代码;
    这里写图片描述
  32. 生成解决方案(或F7),一切正常时,能够在VS2017输出窗口中见到编译成功的输出信息。若是出错,则根据提示修改项目配置或代码后从新生成解决方案,直到成功为止;
    这里写图片描述
    相应文件更新为
    这里写图片描述
  33. 运行ConsoleApplication1程序,在弹出的控制台界面中能够见到输出的“Hello”字符串,表示Dll开发成功。Enjoy!
    这里写图片描述
    这里写图片描述