VC 调试 dll

转载自网络:

VS2008下编写调试dll的一个实例(参考msdn)

演练:创建和使用动态链接库在本演练中,您将创建一个动态链接库 (DLL),其中包含可供其他应用程序使用的有用例程。使用 DLL 是一种重用代码的绝佳方式。您不必在自己创建的每个程序中重新实现这些例程,而只需对这些例程编写一次,然后从需要该功能的应用程序引用它们即可。

 本演练使用本机 C++。有关使用本机 C++ 创建静态库的演练,请参见 演练:创建和使用静态库。有关使用面向公共语言运行库的 Visual C++ 的演练,请参见演练:创建和使用托管程序集。

本演练涵盖以下内容: 创建新的动态链接库 (DLL) 项目 向动态链接库添加类 创建引用动态链接库的应用程序 在控制台应用程序中使用类库的功能 运行应用程序 先决条件本主题假定您具备 C++ 语言的基础知识。

 创建新的动态链接库 (DLL) 项目 从“文件”菜单中,选择“新建”,然后选择“项目…”。

 从“项目类型”窗格中选择“Visual C++”下的“Win32”。

从“模板”窗格中,选择“Win32 控制台应用程序”。

为项目选择一个名称,如“MathFuncsDll”,并将其输入“名称”字段。

为解决方案选择一个名称,如“DynamicLibrary”,并将其输入“解决方案名称”字段。

 按“确定”启动 Win32 应用程序向导。在“Win32 应用程序向导”对话框的“概述”页中,按“下一步”。

 从“Win32 应用程序向导”中的“应用程序设置”页中,选择“应用程序类型”下的“DLL”(如果可用),或者选择“控制台应用程序”(如果“DLL”不可用)。

某些版本的 Visual Studio 不支持使用向导创建 DLL 项目。

您可以稍后对此进行更改,以将项目编译为 DLL。

 从“Win32 应用程序向导”的“应用程序设置”页中,选择“附加选项”下的“空项目”。

按“完成”创建项目。

向动态链接库添加类 若要为新类创建头文件,请从“项目”菜单中选择“添加新项…”。

将显示“添加新项”对话框。从“类别”窗格中,选择“Visual C++”下的“代码”。

从“模板”窗格中,选择“头文件(.h)”。为头文件选择一个名称,如“MathFuncsDll.h”,并按“添加”。

显示一个空白文件。 添加一个名为“MyMathFuncs”的简单类,以执行常见的算术运算,如加、减、乘和除。

代码应与以下内容类似:

 

 // MathFuncsDll.h

namespace MathFuncs

{

class MyMathFuncs

 {

 public:

// Returns a + b

static __declspec(dllexport) double Add(double a, double b);

// Returns a - b

static __declspec(dllexport) double Subtract(double a, double b);

// Returns a * b

static __declspec(dllexport) double Multiply(double a, double b);

 // Returns a / b

// Throws DivideByZeroException if b is 0

static __declspec(dllexport) double Divide(double a, double b);

 };

 }

 

 请注意上面的方法声明中的 __declspec(dllexport) 修饰符。

这些修饰符使 DLL 能够导出该方法以供其他应用程序使用。有关更多信息,请参见 dllexport, dllimport。

若要为新类创建源文件,请从“项目”菜单中选择“添加新项…”。将显示“添加新项”对话框。

从“类别”窗格中,选择“Visual C++”下的“代码”。从“模板”窗格中,选择“C++ 文件(.cpp)”。

为源文件选择一个名称,如“MathFuncsDll.cpp”,并按“添加”。

将显示一个空白文件。 在源文件中实现“MyMathFuncs”的功能。

代码应与以下内容类似:

 

 // MathFuncsDll.cpp

// compile with: /EHsc /LD

#include "MathFuncsDll.h"

#include

using namespace std;

namespace MathFuncs

 {

 double MyMathFuncs::Add(double a, double b)

 { return a + b; }

 

 double MyMathFuncs::Subtract(double a, double b)

 { return a - b; }

 

double MyMathFuncs::Multiply(double a, double b)
{ return a * b; }

 

double MyMathFuncs::Divide(double a, double b)

 {

 if (b == 0)

 {

 throw new invalid_argument("b cannot be zero!");

 }

return a / b;

 }

 }

 

 若要将项目生成为 DLL,请从“项目”菜单中选择“MathFuncsDll,再选择“属性…”。从左窗格中,选择“配置属性”下的“常规”。

从右窗格中,将“配置类型”更改为“动态库(.dll)”。按“确定”保存更改。 注意如果是从命令行生成,请使用 /LD 编译器选项指定输出文件应为 DLL。有关更多信息,请参见 /MD、/MT、/LD(使用运行时库)。

编译该动态链接库,方法是选择“生成”菜单中的“生成解决方案”。这样就创建了一个可供其他程序使用的 DLL。有关 DLL 的更多信息,请参见 DLL。 创建引用动态链接库的应用程序 若要创建引用并使用刚刚创建的动态链接库的应用程序,请从“文件”菜单中选择“新建”,然后选择“项目…”。

从“项目类型”窗格中,选择“Visual C++”下的“Win32”。

 从“模板”窗格中,选择“Win32 控制台应用程序”。 为项目选择一个名称,如“MyExecRefsDll”,并将其输入“名称”字段。从“解决方案”旁边的下拉列表中选择“添入解决方案”。这会将新项目添加到该动态链接库所属的同一个解决方案中。

 按“确定”启动“Win32 应用程序向导”。在“Win32 应用程序向导”对话框的“概述”页中,按“下一步”。

 从“Win32 应用程序向导”的“应用程序设置”页中,选择“应用程序类型”下的“控制台应用程序”。

 从“Win32 应用程序向导”的“应用程序设置”页中,取消选择“附加选项”下的“预编译头”。

 按“完成”创建项目。 在控制台应用程序中使用类库的功能 创建新的控制台应用程序后,将为您创建一个空程序。

源文件的名称与您在前面为项目选择的名称相同。

在本示例中,名为“MyExecRefsDll.cpp”。 若要使用在动态链接库中创建的算术例程,必须引用该动态链接库。

为此,请选择“项目”菜单中的“引用…”。

在“属性页”对话框中,展开“通用属性”节点,并选择“引用”。然后选择“添加新引用…”按钮。有关“引用…”对话框的更多信息,请参见 “ 属性页”对话框 ->“通用属性”->“引用”。 将显示“添加引用”对话框。此对话框列出了所有可以引用的库。“项目”选项卡列出了当前解决方案中的所有项目,以及它们包含的所有库。从“项目”选项卡中,选择“MathFuncsDll”。然后选择“确定”。

有关“添加引用”对话框的更多信息,请参见 “添加引用”对话框。 若要引用动态链接库的头文件,必须修改包含目录路径。为此,请在“属性页”对话框中,展开“配置属性”节点,然后展开“C/C++”节点,并选择“常规”。在“附加包含目录”旁边,键入“MathFuncsDll.h”头文件所在的位置的路径。 动态链接库仅在运行时由可执行文件加载。必须告诉系统在哪里查找“MathFuncsDll.dll”。这是使用 PATH 环境变量实现的。为此,请在“属性页”对话框中,展开“配置属性”节点,并选择“调试”。

在“环境”旁边,键入以下内容:PATH=,其中 应替换为“MathFuncsDll.dll”的实际位置。按“确定”保存进行的所有更改。

 注意如果要从命令行而不是从 Visual Studio 内运行可执行文件,必须从命令提示处手动更新 PATH 环境变量,如下所示:set PATH=%PATH%;,其中 应替换为“MathFuncsDll.dll”的实际位置。 现在,可以在应用程序中使用“MyMathFuncs”类了。

使用以下代码替换“MyExecRefsDll.cpp”的内容:

 

 // MyExecRefsDll.cpp

// compile with: /EHsc /link MathFuncsDll.lib

#include

#include "MathFuncsDll.h"

using namespace std;

int main()

 {

 double a = 7.4;

int b = 99;

cout << "a + b = " << MathFuncs::MyMathFuncs::Add(a, b) << endl;

 

 cout << "a - b = " << MathFuncs::MyMathFuncs::Subtract(a, b) << endl;

cout << "a * b = " << MathFuncs::MyMathFuncs::Multiply(a, b) << endl;

 cout << "a / b = " << MathFuncs::MyMathFuncs::Divide(a, b) << endl;

return 0;

}

 

 通过从“生成”菜单中选择“生成解决方案”,生成可执行文件。

 

8.解决MSVCP90D.dll无法找到问题 : VS 2005在生成可执行文件时使用了一种新的技术,该技术生成的可执行文件会伴随生成一个清单文件(manifest file)(.manifest后缀文件)(其本质上是XML文档,你可以用文本编辑器打开看看),并在链接完成后将该清单文件嵌入到exe文件中(默认情况下)。

 

而在FAT32文件系统中,在处理清单文件阶段,当增量链接时不能完成清单文件的更新(默认情况下),于是造成清单文件嵌入失败,从而使该exe文件运行时没有相应的清单文件而运行失败并提示如上错误 解决方案很多,列举如下:

 1. 由于这是在链接动态运行库出现的问题,所以你可以选择代码生成的连接方式为/MTd而非/MDd,不用这些DLL文件从而避免问题的出现。

该方法有一个很显然的缺点:适用范围有限,并且也不是我等提倡的解决问题的方式,不推荐该方法。

2. 既然跟FAT32系统有关,那么我们可以选择在NTFS文件系统中开发从而避免该问题,此方法同上,也是采用的回避问题的方式,不为我等提倡。

 3. 该方法仍与FAT32有关:在项目的“属性|配置属性|清单工具|常规”中的“使用FAT32解决办法”选择“是”(默认为“否”),重新生成项目即可解决问题。该方法是唯一真正针对问题所在而提出的解决方法,使清单工具可以正确更新。(此方法是官方解决方法,也比较方便,推荐)

4. 既然问题是在更新嵌入的清单文件时发生的,由于FAT32的原因而未能更新嵌入的清单文件,于是我们有如下两种解决方法:(1)不启用增量链接。在项目的“属性|配置属性|链接器|常规”中的“启用增量链接”选择“否”。此方法阻断了问题产生的源头,其每次生成exe文件时都直接嵌入清单文件,而不是默认的根据时戳而决定是否更新清单文件。

(2)不嵌入清单文件。在项目的“属性|配置属性|清单工具|输入和输出”中的“嵌入清单”选择“否”,从而在生成exe文件时附随生成一个清单文件(默认情况下,其文件名为exe文件的全名加上“.manifest”),避免了嵌入清单文件可能失败的问题。在程序运行时,会用到该清单文件。显然,这种方式使可执行程序产生了更多的外部依赖,不推荐。

 另外,还有一个不能称为方法的土办法:每次Build前手动删除*.ilk文件(增量链接文件)(当然可以在项目属性中写入删除命令,使其自动执行),不推荐该土办法。

 

 最后,总结一下:

 1. 此问题只在特定条件下才会出现:在FAT32文件系统中编译、默认设置(增量模式、不启用FAT32解决方案、嵌入清单文件)、非第一次生成可执行文件文件(即在增量连接、更新清单文件时)。

 2. 解决方案1和4.1方便实用,推荐使用。 9.运行应用程序 确保选择“MyExecRefsDll”作为默认项目。从“解决方案资源管理器”中,选择“MyExecRefsDll”,然后选择“项目”菜单中的“设为启动项目”。 若要运行项目,请选择“调试”菜单中的“开始执行(不调试)”。输出应如下所示: 复制代码 a + b = 106.4 a - b = -91.6 a * b = 732.6 a / b = 0.0747475

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: vc6 dm.dll 是 Microsoft Visual C++ 6.0 开发环境提供的一个动态链接库文件,在一些编写使用VC++ 6.0的程序中可能会用到。该文件主要包含了一些在VC++ 6.0开发环境中常用的函数和类的定义,供程序调用和使用。 要下载 vc6 dm.dll,可以通过以下步骤进行: 1. 进入一个可靠的软件下载网站,如官方或受信任的第三方软件库网站。 2. 在搜索框中输入 "vc6 dm.dll",然后按下回车键。 3. 在搜索结果中找到适合您系统版本和需求的版本,然后点击下载。 4. 根据下载网站的提示,选择保存文件的位置,并等待下载完成。 tlloc.dll 是一个未知的 DLL 文件,如果你是根据自己的需求而寻找该文件下载的,建议先了解该 DLL 文件的用途和来源,确保其安全性和合法性。通常来说,为了确保从可靠的来源下载 DLL 文件,可以按照以下步骤进行操作: 1. 确认需要该 DLL 文件的确切名称以及与之关联的软件或服务。 2. 在官方厂商网站、软件开发者的官方网站或受信任的第三方软件库网站上搜索该 DLL 文件。 3. 在搜索结果中找到与您的需求最相符的版本,然后点击下载。 4. 根据下载网站的提示,选择保存文件的位置,并等待下载完成。 请记住,在下载任何 DLL 文件时,要确保从可靠的来源获得,并且在下载和使用之前,最好对其进行杀毒扫描以确保其安全。此外,应避免从不受信任的来源直接下载 DLL 文件,以免带来潜在的风险和安全问题。 ### 回答2: VC6 dm.dll和tlloc.dll是Visual C++ 6.0的两个动态链接库文件。它们主要用于支持和提供某些语言环境下的本地化功能。 VC6 dm.dll是Visual C++ 6.0的资源管理库,它负责处理和管理应用程序的资源文件,如可执行文件、动态链接库和静态链接库等。它提供了资源的加载、卸载、修改等功能,使得开发人员可以更加方便地对资源进行操作和管理。 VC6 tlloc.dll是Visual C++ 6.0的本地化库,它提供了多语言环境下的本地化支持。它包含了各种语言的本地化资源文件,如文字、图片、声音等,以便应用程序可以根据系统或用户的语言环境自动选择并加载相应的本地化资源,从而实现程序的国际化和本地化。 要下载VC6 dm.dll和tlloc.dll,可以在互联网上搜索相关的资源下载网站或开发人员社区。在这些网站或社区中,可以找到相应版本的库文件,并进行下载和安装。下载后,将这两个dll文件复制到你的应用程序所在的目录下,或者将它们添加到系统的dll搜索路径中。然后,你的应用程序就可以正常使用这两个库文件提供的功能了。 需要注意的是,下载dll文件时要选择可靠的来源,并确保下载的dll文件与你的开发环境的版本相匹配。否则,可能会导致兼容性问题或安全隐患。因此,建议在下载和使用dll文件前,仔细验证其来源和版本的兼容性,以确保应用程序的正常运行。 ### 回答3: VC6 dm.dll 和 tlloc.dll 是一些动态链接库文件,通常与VC6(Visual C++ 6.0)编译器相关联。 VC6 dm.dll是一个用于调试管理器(Debug Manager)的动态链接库文件,它提供了与调试相关的函数和接口,用于支持在VC6中进行代码调试和错误追踪。当你在使用VC6进行编程时,可能会遇到需要使用dm.dll的情况。你可以在一些第三方软件下载站或者开发者社区中找到并下载该文件。 TLLOC.DLL是TLLOC(Type Library Local)的缩写,是一个类型库本地化工具的动态链接库文件,用于支持VC6程序中的本地化过程。本地化是指将一个程序适应特定语言、地区或文化的过程,将程序中的文本、资源和用户界面翻译成多种语言或进行相关调整。TLLOC.dll提供了一些函数和接口,用于在VC6中处理本地化相关的任务。你也可以在一些提供VC6开发资源的网站上下载该文件。 请注意,下载并使用这些动态链接库文件时,请确保从可信来源下载,以避免从不可信的网站下载到带有恶意软件的文件。此外,建议根据你的具体需要,咨询相关的开发者社区或者参考相关的文档,以确保正确地使用这些文件并避免出现任何问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值