vs断点调试技巧(一)

 

  
设置断点:在以下图中的红色圆点处设置断点,红色圆点表示已经在这行设置断点。快捷键F9。

启动调试:按F5或者点击左边红框中的按钮。右边框是开始执行(不调试)Ctrl+F5。php

调试工具栏:下面是工具栏中对应的名称和快捷键。html

在调试过程当中F5是执行到下一个断点。F11是逐语句,在执行到下图中的断点时,按F11会执行到Fibonacci方法里面逐步记录执行过程。F10是逐过程,与逐语句不一样的是,在执行到下图中断点时,再执行会执行断点下面的语句,而不是去执行语句中的方法。数组

局部变量:在调试过程当中能够查看局部变量窗口,以下图里面会有变量的当前状态。若是找不到的话在app

数组的状态表示以下图:工具

InteliTrace记录每一步的调试状态。url

条件中断spa

开发人员设置断点,运行程序,利用不一样的输入触发断点,而后在断点处手工检查是否知足某些特定的条件,从而决定是否继续调查。若是当前场景不是他们想要的,按F5继续运行程序,尝试别的输入,手动重复刚才的过程。.net

针对上述状况,Visual Studio提供了一个方便得多的功能——“条件中断”。只有当程序知足了开发人员预设的条件后,条件断点才会被触发,调试器中断。这将避免频繁地手工检查/恢复程序运行,大量减小调试过程当中的手工和烦琐工做。线程

如何设置条件断点:调试

设置条件断点很是容易。在特定的行上,按F9设置断点。

而后右击断点–编辑窗口左侧的红点,在上下文菜单上选择“条件”。

这时弹出一个对话框供你设置激活该断点所需的条件。好比:咱们但愿只有当x==5时,调试才中断。咱们能够写出以下的表达式:

如今我再运行这个程序按F5达到条件断点,只有当x等于5时,程序运行才会被中断。对于其它条件下的x值,断点将被跳过。

记录到达断点次数

有时你但愿,只有当第N次知足条件的运行到达断点时,才中断程序运行。例如:当第一次命中断点。能够经过右击断点,而后在弹出菜单上选择“命中次数”菜单命令实现。

这时系统弹出一个对话框,它容许你指定:(1)当知足条件,并且进入断点的累计次数等于N时,断点命中一次。(2)当知足条件,并且进入断点的累计次数是N的倍数时,断点命中一次。(3)当知足条件,并且进入断点的累计次数大于N时,每次命中断点。

注意:若是多个条件同时用的话,结果取交集。

断点筛选器

例如,在调试一个服务程序时在其内部打上了断点,因为这是一个公用的服务不但愿其余访问这个服务的程序被所设断点调试干扰,怎么办?断点筛选器就是限制只在某些进程和线程中设置断点。筛选器文本框中输入如下一个或多个子句,可使用&(AND)、||(OR)、!(NOT)和圆括号组合这些子句描述应在何处设置断点的表达式,或者清除该表达式以便在全部进程和线程中设置断点。好比,但愿断点只在被机器名为xye-PC的机器访问时才触发,咱们能够右击断点进行断点筛选器设置。当其余机器访问程序的时候断点不会触发,其余机器访问时感受不到断点的存在。

跟踪点进入断点时的自定义操做

许多人不知道“跟踪点(TrackPoints)”这个调试功能。“跟踪点“是种特殊的断点,当它被命中时,它会触发一系列自定义操做。若是你想观察程序的行为,而又不想中断调试的时候,这个功能尤为有用。

我将用一个简单的控制台程序来演示如何使用“跟踪点”。以下是斐波那契数列的一个递归实现:

以上程序中,咱们使用Console.WriteLine() 输出针对特定输入值生成的最终斐波那契数列。若是但愿在调试器里观察操做中每一次递归运算后的数列而又不实际中断程序运行,该怎么办呢?“跟踪点”能够轻松实现。

设置跟踪点:

你能够在特定的行上,按F9加跟踪点。而后右击断点,在上下文菜单中选择“命中条件”:

在弹出对话框上,你能够设置命中该断点时,所触发的事件。

在上面例子中,咱们设定一旦命中断点时就打印追踪信息。注意,咱们已经把局部变量“x”的值,做为追踪信息的一部分输出。局部变量能够经过{变 量名}语法输出。你还能够利用系统内置的命令($CALLER, $CALLSTACK, $FUNCTION等等),在追踪信息中输出经常使用的调试值。

在上例中,咱们同时选中了底端的“continue execution“选项,这说明咱们不但愿程序中断调试状态,而是继续运行。惟一的不一样是:每次断点条件知足时,咱们的自定义追踪信息都将被输出。

如今当咱们运行程序时,会发现自定义追踪信息自动显示在Visual Studio的“输出“窗口里。这让咱们很容易看到程序的递归调用过程:

你也能够选择往应用程序中添加一个自定义追踪信息的监听器。这时追踪点的输出信息将经过它输出,而不是Visual Studio的“输出“窗口。

Tag:VS2010   调试   
查看标识获取更多信息
查看标识获取更多信息
 
 
 
 
查看标识获取更多信息
相关文章
相关标签/搜索