首页 > 编程知识 正文

C++调试(mfc调用dll)

时间:2023-05-04 14:51:11 阅读:75920 作者:2237

BoundsChecker是一个运行时间错误检测工具,主要识别程序运行时遇到的各种错误。 BoundsChecker可以检测到的错误如下:

1、指针操作与内存、资源泄露错误,如:

内存泄漏;

资源泄露;

对指针变量的错误操作。

2、内存操作错误,如:

内存读取、写入溢出

使用未初始化的内存。

3、API函数的使用方法错误

成功安装BoundsChecker后,VC集成开发环境中将添加一个名为BoundsChecker的菜单。 如下所示。

BoundsChecker非常好地集成到VC集成开发环境中。

要使用BoundsChecker检测程序的运行时错误,可以在两种使用模式之间进行选择。 一个模式称为活动检查,一个模式称为FinalCheck。 以下分别介绍。1.1 ActiveCheck

ActiveCheck是BoundsChecker提供的方便快捷的错误检测模式,可检测的错误类型有限,仅包括内存泄漏错误、资源泄漏错误和使用API函数错误。

要使用ActiveCheck模式检测程序运行时错误,只需在VC集成开发环境中打开BoundsChecker功能,然后在调试状态下运行程序。 此时,ActiveCheck会在后台自动运行,随时检测程序是否发生错误。 说明具体的使用步骤。111 用ActiveCheck来检测错误

使用ActiveCheck的具体操作步骤如下。

首先,打开要在VC集成开发环境中测试的程序,以确保项目处于调试编译状态。

然后,确保在VC集成开发环境中选择了“boundschecker/integrated debugging”和“boundschecker/reporterrorsandevents”菜单项。 只有选择了这两个选项,BoundsChecker才能在程序运行时起作用。

最后,在VC集成开发环境中选择[Build/Start Debug/Go]菜单命令,在调试状态下运行程序时,活动检查也将在后台运行。

此时,可以根据编写的测试用例操作程序。 程序执行的代码由ActiveCheck记录(如果存在错误)。

我可以说一件事。 “[BoundsChecker]”菜单中有“[报告错误信息]”。 如下图所示。

此菜单项在活动检查模式和下面介绍的FinalCheck模式中的工作方式相同。 也就是说,如果不选择此选项,BoundsChecker将记录在程序运行时发现的各种错误,并在程序退出后报告这些错误。 如果选中此菜单项,当BoundsChecker在程序运行时发现错误时,将立即显示以下对话框并提示:

按照图中记载的编号顺序说明对话框内各按钮的功能。

按钮1 )单击此按钮表示首先忽略此错误,然后继续程序。

按钮2 )单击此按钮可立即跳至有问题的代码行。 处理完问题后,可以单击[Build/Start Debug/Go]菜单项继续执行程序并进行检查。

按钮3 )单击此按钮可将此错误添加到忽略的错误列表中,如果再次出现此问题,BoundsChecker将不会报告。

按钮4 )单击此按钮可立即停止程序的执行。

按钮5 )单击此按钮可查看当前内存的申请、使用情况。

按钮6 :单击此按钮可获得有关当前此错误的帮助信息。

按钮7、8 )这两个按钮与boundscheckerreporterrorsimmediately和boundscheckerreporterrorsandevent菜单命令的功能完全相同

按钮9 )单击此按钮可显示/隐藏与此错误相关的函数调用栈的状态以及具体错误代码行的位置。

是否选择“boundschecker/reporterrorsimmediately”菜单项取决于您的喜好和测试时的具体情况。 如果BoundsChecker想实时报告程序运行时发现的错误,请选择此菜单项,等待操作完成,然后如果想统一分析操作中BoundsChecker发现的错误,请选择此菜单项在平时的使用中偏向于后者。112 分析错误

在你的操作全部结束并退出程序后,

BoundsChecker将显示检测到的错误列表。 必须分析列表中列出的错误以确定错误的原因和位置。

错误检测结果列表列出了在程序运行时ActiveCheck检测到的所有内存泄漏、资源泄漏和API函数的使用错误

误的相关信息。如下图所示:


在左边的窗口中,逐条列出了程序在内存、资源、API 函数使用上的问题,包括:该问题的种类,该问题发生的次数,如果是内存泄露,损失了多少内存,以及发生该问题的代码位置等等。柔弱的夕阳用鼠标单击选中某一条记录时,在右边的窗口中会显示出与该条错误记录相对应的函数调用堆栈情况。柔弱的夕阳用鼠标双击某一条错误记录时,会定位到引发该错误的源代码处。
好了,BoundsChecker在ActiveCheck模式下的使用方法至此介绍完了,是不是很简单?
在ActiveCheck模式下检测程序时,程序的运行速度基本不受影响,但其缺点是检测的错误种类有限,即只能检查出内存泄露错误、资源泄露错误、API函数使用错误。BoundsChecker 提供了另外一种检测错误的模式—— FinalCheck,也就是我们在前面提到的BoundsChecker的第二种使用模式。 FinalCheck可以检测出程序中更多的错误。下面我们就对它进行介绍。

1.2 用 FinalCheck检测更多的错误 
FinalCheck具有BoundsChecker提供的所有检错功能。FinalCheck 是ActiveCheck的超集,它除了能够检测出ActiveCheck能够检测出的错误,还能发现很多 ActiveCheck 不能检测到的错误,包括:指针操作错误、内存操作溢出、使用未初始化的内存等等,并且,对于ActiveCheck能检测出的错误,FinalCheck能够给出关于错误更详细的信息。所以,我们可以把FinalCheck认为是ActiveCheck的功能增强版。我们付出的代价是:程序的运行速度会变慢,有时甚至会变的很慢。

要想在FinalCheck 模式下测试程序,不能使用VC++集成开发环境提供的编译连接器来构造程序,而必须要使用BoundsChecker提供的编译连接器来编译连接程序。当 BoundsChecker的编译连接器编译连接程序时,会向程序中插装一些错误检测代码,这也就是FinalCheck能够比ActiveCheck找到更多错误的原因。

下面就

介绍一下如何在FinalCheck模式下对程序进行测试:

1在VC++集成开发环境中打开你所要测试的项目。

2由于要使用BoundsChecker的编译连接器重新编译连接程序,所以我们为BoundsChecker独自构造一个文件夹。在VC++集成开发环境中,具体操作方法是:

A)点击[ Build/Configurations...]菜单命令。

B)在弹出的对话框中点击 Add 按钮。在Configuration 编辑框中添入你为BoundsChecker创建的文件夹的名称,这个名称是任意的,比如我们取名为BoundChecker。

C)在 Copy settings from组合框中选中 XXX—Win32 Debug项,然后点击OK按钮,接着点击Close按钮。

现在,我们已经为FinalCheck构造好了一个文件夹。

3 点击[Build/Set Active Configuration…] 菜单命令,选中你刚才为BoundsChecker建的文件夹, 然后点击OK按钮。这样BoundsChecker编译连接程序时生成的中间文件、可执行程序,都会被放到该文件夹下。

4选择[BoundsChecker/Rebuild All with BoundsChecker] 菜单命令,对程序重新进行编译连接,也就是在这时,BoundsChecker向被测程序的代码中加入了错误检测码。编译连接完成后,BoundsChecker会在你为BoundsChecker构造的文件夹中生成可执行文件。

在FinalCheck模式下对程序进行检测的准备工作都已经做好,这时可以启动程序开始测试了, 

操作步骤与在ActiveChecker模式下没什么区别。具体步骤如下:

确保VC++集成开发环境中[BoundsChecker/ Integrated Debugging]菜单项和[BoundsChecker/Report Errors and Events]菜单项处于选中状态。 
点击[ BuildStart Debug]菜单,选中“Go” 菜单项。程序开始在Debug状态下运行。 
按照你制定好的测试用例,对程序进行操作。  
当BoundsChecker检测到了错误时,会弹出窗口向你汇报,你可以当时就进行处理,也可以等到你的操作全部完成,退出程序之后再对列出的这些错误进行分析。这完全取决于你是否选中了[BoundsChecker/Report Errors Immediately] 菜单项。 
退出程序后,BoundsChecker会给出错误检测结果列表。该错误列表与ActiveChecker给出的错误列表的查看方法完全一样。只不过这个列表中所报告的信息会更多、更详细一些。  
好了,BoundsChecker在FinalCheck模式下的使用也介绍完了。ActiveChecker、FinalCheck这两种模式,比较而言各有长短。ActiveChecker使用方便,只需在Debug状态下直接运行程序即可,并且程序的运行速度较快,但检测的错误种类有限;FinalCheck模式下,需要使用BoundsChecker的编译连接器重新编译连接生成可执行程序,并且程序的运行速度比较慢,但检测的错误种类、提供的错误相关信息要多于ActiveChecker。所以,何时使用何种模式,应根据当时的具体情况而定。

1.3 检测Win32 API函数的兼容性
BoundsChecker还提供了一个功能——检测程序中使用的Win32 API函数在不同平台上的兼容性。该功能与前面提到的ActiveChecker、FinalCheck模式没有什么关系,它是独立的一个功能。

虽然大多数Win32 API函数都适用于Win95、Win98、Win2000、WinNT等不同的Windows操作系统平台,但并不是所有的API函数都满足这种情况。你可能不知不觉的使用了在某一个平台下允许,在另一个平台下却不允许使用的API函数,而项目的要求是:程序能够在这两种平台下运行。 BoundsChecker提供的这个检测Win32 API函数兼容性的功能,恰好能够处理这个问题。

该功能的使用方法如下:

启动[BoundsChecker/View/Compliance Report]菜单命令,如下图所示:



在对话框中选择程序承诺能够运行的平台,以及被要求遵从的其他标准(标准C和扩展的标准C),点击“OK”按钮,BoundChecker会给出兼容性检测报告。

1.4 忽略错误
在某些情况下,我们需要忽略BoundsChecker报告的一些错误,这些情况包括:

1 误报。BoundsChecker 指定程序中的某段代码存在错误,但经过我们的仔细检查,证实程序确实没有这个错误,这是BoundsChecker的误报。工具毕竟是工具,它只能依照为它制定的算法行事,所以会有误报的情形发生。但千万不要轻易认定某一个错误为误报,一定要对错误进行仔细的分析,确定是真正的误报。

2第三方的代码。BoundsChecker指定的错误发生位置在第三方提供的代码中,包括第三方提供的程序库、DLL、OCX等。对于这种情况,我们也要先进行认真的检查,确定不是由于我们错误的使用第三方的代码引起的。如果最后确定不是我们的原因,则这样的错误报告可以忽略。

1.5 其他
还有一点需要强调,使用BoundsChecker对程序进行测试时,需要有程序的源代码。如果没有源码,BoundsChecker虽然也可以打开EXE文件将其执行起来,但得出的测试结果经常是不正确的,因此也就没有太大的意义。

另外,除了可以在VC++集成开发环境中使用BoundChecker外,从 [开始菜单] 中启动BoundChecker,然后打开经BoundChecker编译连接生成的可执行文件,也可以对程序进行测试,操作方法与集成到VC++集成开发环境中的BoundChecker的操作方法是一样的,在此就不赘述了。

至此,BoundChecker所提供的功能全部介绍完了。

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。