VS中静态库和DLL的使用

参考微软官方文档:创建和使用自己的动态链接库 (C++)
创建并使用静态库

静态库使用

创建静态库项目并添加类

1、在菜单栏上,选择“文件”>“新建”>“项目”,打开“创建新项目”对话框。

2、在对话框顶部,将“语言”设置为“C++”,将“平台”设置为“Windows”,并将“项目类型”设置为“库”。

3、从经过筛选的项目类型列表中,选择“Windows 桌面向导”,然后选择“下一步” 。

4、在“配置新项目”页面,在“项目名称”框中输入“MathLibrary”,以指定项目的名称 。 在“解决方案名称”框中输入“StaticMath” 。 选择“创建”按钮,打开“Windows 桌面项目”对话框 。

5、在“Windows 桌面项目”对话框的“应用程序类型”下,选择“静态库(.lib)” 。

6、在“其他选项”下,取消选中“预编译标头”复选框(如果已选中) 。 选中“空项目”框 。

7、选择“确定”,创建项目 。

8、右键添加头文件和源文件,在头文件中添加类的声明,在源文件中实现类的功能。

9、点击生成>生成解决方案

创建引用静态库的C++控制台应用

1、在“解决方案资源管理器”中,右键单击顶部节点“解决方案 StaticMath”,打开快捷菜单 。 选择“添加”>“新建项目”,打开“添加新项目”对话框 。

2、在对话框的顶部,将“项目类型”筛选器设置为“控制台” 。

3、从筛选的项目类型列表中,选择“控制台应用”,然后选择“下一步” 。 在下一页中,在“名称”框中输入“MathClient”,以指定项目的名称 。

4、选择“创建” 按钮创建客户端项目。

5、创建控制台应用后,将为你创建一个空程序。 源文件的名称与你之前选择的名称相同。 在此示例中,命名为 MathClient.cpp。

在应用中使用静态库功能并运行应用(重点!)

1、右键MathClient项目,选择添加>引用,在列出的可以引用的库中选择“MathLibrary”

2、右键MathClient项目,属性,将配置下拉列表设置为所有配置,将平台下拉列表设置为所有平台

3、选择“配置属性”>“C/C++”>“常规”,在附加包含目录中属性中指定“MathLibrary”目录的路径

4、在MathClient.cpp中添加 #include “MathLibrary.h”

5、若要生成可执行文件,请在菜单栏上选择“生成”>“生成解决方案” 。

6、右键单击打开“解决方案资源管理器”中“MathClient”的快捷菜单,然后选择“设置为启动项目” 。

7、“调试” >“开始执行(不调试)”


动态库使用

创建 DLL 时,请考虑客户端应用如何使用它。 若要调用函数或访问由 DLL 导出的数据,客户端源代码必须在编译时具有可用的声明。 在链接时间,链接器需要信息来解析函数调用或数据访问。 而 DLL 在“导入库”中提供此信息,导入库是包含有关如何查找函数和数据的信息的文件,而不是实际代码 。 而在运行时,DLL 必须可供客户端使用,位于操作系统可以找到的位置。

无论是你自己的还是来自第三方的信息,客户端应用项目都需要几条信息才能使用 DLL。 它需要查找声明 DLL 导出的标头、链接器的导入库和 DLL 本身。 一种解决方案是将所有这些文件复制到客户端项目中。 对于在客户端处于开发阶段时不太可能更改的第三方 DLL,此方法可能是使用它们的最佳方法。

但是,如果还要同时生成 DLL,最好避免重复。 如果创建了正在开发的 DLL 文件的本地副本,可能会意外更改一个副本而不是另一个中的头文件,或使用过期的库。为避免不同步的代码,建议在客户端项目中设置包含路径,使其直接包括 DLL 项目中的 DLL 头文件。 此外,在客户端项目中设置库路径以包括 DLL 项目中的 DLL 导入库最后,将生成的 DLL 从 DLL 项目复制到客户端生成输出目录中。 此步骤允许客户端应用使用生成的同一 DLL 代码。

创建DLL项目

1、在菜单栏上,选择“文件”>“新建”>“项目”,打开“创建新项目”对话框 。

2、“创建新项目”对话框的屏幕截图,其中突出显示了动态链接库模板。

3、在对话框顶部,将“语言”设置为“C++”,将“平台”设置为“Windows”,并将“项目类型”设置为“库”。

4、从经过筛选的项目类型列表中,选择“动态链接库(DLL)”,然后选择“下一步” 。

5、在“配置新项目”页面,在“项目名称”框中输入“MathLibrary”,以指定项目的名称 。 保留默认“位置”和“解决方案名称”值 。 将“解决方案”设置为“创建新解决方案” 。 如果“将解决方案和项目放在同一目录中”已选中,则取消选中 。

6、选择“创建” 按钮创建项目。

7、在项目中添加新建项,创建头文件和源文件并添加相关功能代码

8、选择“生成”>“生成解决方案” 。 DLL 和相关编译器输出放在解决方案文件夹正下方的“Debug”文件夹中 。 如果创建发布版本,该输出会放置在“Release”文件夹中 。

创建使用DLL的客户端应用

1、在菜单栏上,选择“文件”>“新建”>“项目”,打开“创建新项目”对话框。

2、在对话框顶部,将“语言”设置为“C++”,将“平台”设置为“Windows”,并将“项目类型”设置为“控制台”。

3、从筛选的项目类型列表中,选择“控制台应用”,然后选择“下一步” 。

4、在“配置新项目”页面,在“项目名称”框中输入“MathClient”,以指定项目的名称 。 保留默认“位置”和“解决方案名称”值 。 将“解决方案”设置为“创建新解决方案” 。 如果“将解决方案和项目放在同一目录中”已选中,则取消选中 。

5、“创建新项目”对话框的屏幕截图,其中突出显示了“控制台应用”选项。

6、选择“创建” 按钮创建客户端项目。

在应用中使用DLL库(重点!)

要在源代码中调用 MathLibrary 函数,项目必须包括 MathLibrary.h 文件 。 可以将此头文件复制到客户端应用项目中,然后将其作为现有项添加到项目中。 对于第三方库,此方法可能是一个不错的选择。

但是,如果同时处理 DLL 的代码和客户端的代码,为了避免头文件可能会不同步的问题,请设置项目中的“附加包含目录” 路径,使其包含指向头文件的路径。

1、右键单击“解决方案资源管理器” 中的“MathClient” 节点以打开“属性页” 对话框。

2、在“配置”下拉框中,选择“所有配置”(如果尚未选择) 。

3、在左窗格中,选择“配置属性”>“C/C++”>“常规” 。

4、在属性窗格中,选择“附加包含目录” 编辑框旁的下拉控件,然后选择“编辑” 。

5、在“附加包含目录” 对话框的顶部窗格中双击以启用编辑控件。 或者,选择文件夹图标以创建新条目。

6、在编辑控件中,指定指向 MathLibrary.h 头文件的位置的路径。 可选择省略号 (…) 控件浏览到正确的文件夹 。

还可将客户端源文件中的相对路径输入到包含 DLL 头文件的文件夹。 如果已按照指示将客户端项目置于 DLL 的单独解决方案中,则相对路径应如下所示:

…\MathLibrary\MathLibrary

如果 DLL 和客户端项目位于同一解决方案中,则相对路径可能如下所示:

…\MathLibrary

如果 DLL 和客户端项目位于其他文件夹中,请调整相对路径以进行匹配。 或者,使用省略号控件浏览文件夹。

7、在“附加包含项目”对话框中输入标头文件的路径后,选择“确定”按钮 。 在“属性页”对话框中,选择“确定”按钮以保存更改 。

此代码可进行编译,但不能链接。 如果现在生成客户端应用,则错误列表会显示几个 LNK2019 错误。 这是因为项目丢失了一些信息:你尚未指定项目在 MathLibrary.lib 库上有依赖项 。 而且,你尚未告诉链接器如何查找 MathLibrary.lib 文件

要解决此问题,可以直接将库文件复制到客户端应用项目中。 链接器将自动查找并使用它。 但是,如果库和客户端应用都处于开发过程中,则可能会导致一个副本中的更改未在另一个副本中显示。 要避免此问题,可以设置附加依赖项属性,告诉生成系统项目依赖于 MathLibrary.lib 。 此外,还可设置项目中的“附加库目录” 路径,使其在链接时包含指向原始库的路径。

1、右键单击“解决方案资源管理器”中的“MathClient”节点,然后选择“属性”以打开“属性页”对话框 。

2、在“配置”下拉框中,选择“所有配置”(如果尚未选择) 。 它可确保任何属性更改同时应用于调试和发布版本。

3、在左窗格中,选择“配置属性”>“链接器”>“输入”。 在属性窗格中,选择“附加依赖项”编辑框旁的下拉控件,然后选择“编辑” 。

4、在“附加依赖项”对话框中,将 MathLibrary.lib 添加到顶部编辑控件的列表中 。

5、选择“确定” 返回到“属性页” 对话框。

6、在左窗格中,选择**“配置属性”>“链接器”>“常规”** 。 在属性窗格中,选择“附加库目录”编辑框旁的下拉控件,然后选择“编辑” 。

7、在“附加库目录” 对话框的顶部窗格中双击以启用编辑控件。 在编辑控件中,指定指向 MathLibrary.lib 文件位置的路径。 默认情况下,它位于 DLL 解决方案文件夹下的“Debug”文件夹中 。 如果创建发布版本,该文件会放置在“Release”文件夹中 。 可以使用 $(IntDir) 宏,这样无论创建的是哪种版本,链接器都可找到 DLL。 如果已按照指示将客户端项目置于 DLL 项目的单独解决方案中,则相对路径应如下所示:

…\MathLibrary$(IntDir)

如果 DLL 和客户端项目位于其他位置,请调整相对路径以进行匹配。
在这里插入图片描述

8、在“附加库目录”对话框中输入指向库文件的路径后,选择“确定”按钮返回到“属性页”对话框 。 选择“确定”以保存属性更改 。

客户端应用现在可以成功编译和链接,但它仍未具备运行所需的全部条件。 当操作系统加载应用时,它会查找 MathLibrary DLL。 如果在某些系统目录、环境路径或本地应用目录中找不到 DLL,则加载会失败。
避免此问题的一种方法将 DLL 复制到包含客户端可执行文件的目录中,作为生成过程的一部分可将“后期生成事件”添加到项目中,以此添加一条命令,将 DLL 复制到生成输出目录 。 此处指定的命令仅在 DLL 丢失或发生更改时才复制它。 此命令使用宏根据生成配置在调试或发布位置之间进行复制。

1、右键单击“解决方案资源管理器”中的“MathClient”节点,然后选择“属性”以打开“属性页”对话框 。

2、在“配置” 下拉框中,选择“所有配置” (如果尚未选择)。

3、在左窗格中,选择“配置属性”>“生成时间”>“后期生成事件” 。

4、在属性窗格中,在“命令行”字段中选择编辑控件 。 如果已按照指示将客户端项目置于 DLL 项目的单独解决方案中,则输入以下命令:

xcopy /y /d “…\MathLibrary$(IntDir)MathLibrary.dll” “$(OutDir)”

如果 DLL 和客户端项目在其他目录中,请更改 DLL 的相对路径以进行匹配。
在这里插入图片描述
5、选择“确定” 按钮以保存对项目属性所做的更改。

最后,在菜单栏上选择“生成”>“生成解决方案”来生成应用程序 。

VS可配置输出路径

在lib的属性页中可配置lib最终输出位置和修改名称。
在这里插入图片描述
dll的输出路径和名称也可进行修改:
在这里插入图片描述
注意dll和lib的属性页是不同的,lib没有连接器选项,而dll没有文件管理程序这一项。

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MFC 解压 7z 文件使用 7-Zip 的静态库 "7z.lib" 时,不需要使用 "7z.dll" 文件。下面是一个示例代码: ```cpp #include "7z/7z.h" #include "7z/7zAlloc.h" #include "7z/7zFile.h" // 解压 7z 文件到指定目录 bool Extract7zFile(LPCTSTR lpszFilePath, LPCTSTR lpszTargetPath) { // 打开 7z 文件 CFileInStream archiveFile; if (InFile_Open(&archiveFile.file, lpszFilePath) != 0) { return false; } // 初始化 7z 解压缩器 CLookToRead2 lookStream; LookToRead2_CreateVTable(&lookStream, false); lookStream.buf = nullptr; lookStream.bufSize = 0; lookStream.realStream = &archiveFile.vt; CDecodedFileInfo fileInfo; SzArEx_Init(&fileInfo.db); SRes res = SzArEx_Open(&fileInfo.db, &lookStream.vt, &g_Alloc, &g_Alloc); if (res != SZ_OK) { InFile_Close(&archiveFile.file); return false; } // 遍历解压缩器的所有文件 UInt32 numItems = fileInfo.db.NumFiles; for (UInt32 i = 0; i < numItems; i++) { // 获取文件名称 size_t fileNameLen; SzArEx_GetFileNameUtf16(&fileInfo.db, i, nullptr, &fileNameLen); CString fileName; fileName.GetBufferSetLength(fileNameLen); SzArEx_GetFileNameUtf16(&fileInfo.db, i, (WCHAR*)fileName.GetBuffer(), &fileNameLen); fileName.ReleaseBuffer(); // 拼接文件路径 CString filePath = lpszTargetPath; filePath += fileName; // 创建目录 CString dirPath = filePath.Left(filePath.ReverseFind('\\') + 1); if (!PathFileExists(dirPath)) { SHCreateDirectoryEx(NULL, dirPath, NULL); } // 打开输出文件流 CFileOutStream outFileStream; if (OutFile_Open(&outFileStream.file, filePath) != 0) { continue; } // 解压缩文件 UInt32 blockIndex = fileInfo.db.FileIndexToFolderIndex[i]; UInt64 unpackSize = SzArEx_GetFileSize(&fileInfo.db, i); res = SzArEx_Extract(&fileInfo.db, &lookStream.vt, blockIndex, &outFileStream.vt, &unpackSize, &g_Alloc, &g_Alloc); OutFile_Close(&outFileStream.file); if (res != SZ_OK) { continue; } } // 关闭 7z 文件 SzArEx_Free(&fileInfo.db, &g_Alloc); InFile_Close(&archiveFile.file); return true; } ``` 该示例代码使用了 7-Zip 的静态库,并通过调用其提供的函数实现了 7z 文件的解压缩。 需要注意的是,为了正确使用 7-Zip 的静态库,需要将 "7z.lib" 文件添加到项目,并将其路径添加到项目属性的 "VC++ 目录" 和 "链接器 -> 输入 -> 附加依赖项" 。同时,还需要包含 "7z" 目录下的头文件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值