Visual Studio - 调试

异常处理机制

windows预定义了一系列的异常错误码,每种程序异常都有一个对应的错误码,windows系统将这些类似键值对关系的数据存储在异常处理表中(称为SEH结构化异常处理表)。当CPU执行程序指令时,如果指令出现错误,那么CPU会识别错误所对应的错误码,接着执行流程会进入SEH,查找错误码所对应的处理程序,C++、.Net的程序异常都是由RaiseException函数进行处理,异常被处理之后CPU才会继续执行下一句指令。

    异常码                          处理程序
0xC0000005    AccessViolationExceptionHandler( )
0x80000003     LaunchOrNotifyDebugger( )
……

比如打开一个编译后的程序(如:CUI程序MyApp.exe),当程序出现异常后会被CPU挂起,会进入RaiseException,假如代码具有try、catch块,则会把异常交给try、catch处理,如果没有try、catch块,那么异常会交给windows自带的异常处理块,该异常处理块会检查MyApp.exe的程序代码是否是由某个调试器运行起来的,如果是,就向调试器发出通知,这样,调试器就会对异常做出处理,比如visual studio自带的调试器就是在此时抛出异常信息的,但如果MyApp.exe的程序代码并不是由某个调试器运行起来的,那么window就要调用内置的Dr Watson调试器对异常代码进行"尸检",也即它会通过一个提示框将错误信息抛出。

开启web应用程序的调试

打开web.config,在System.Web配置节将compilation 设为true即可开启调试

<system.web>
     <compilation debug="false" targetFramework="4.6.1" />
</system.web>

当设为false后:

断点调试

普通断点

光标定位到所在行或直接单击行左侧空白处,会显示一个红色图标表示断点到此处,程序运行时执行到断点处就会暂停。

断点后按F5或直接点击启动按钮,当程序执行到断点处会暂停,此时可以查看变量当前的值。

条件

执行到断点处并不会暂停,直到满足预设的条件后才会暂停。右击断点的红图标 - 条件,可以看到与条件有关的三个下拉选项

条件表达式:可设置一个当前程序所使用的语言的表达式,比如C#的表达式,表达式为true时就会进入断点,程序会暂停。

命中次数:使循环体循环到某个特定次数的时候才暂停,可设置==、>=或数倍于,可描述为:当前循环次数==或>=或数倍于

筛选器:指定当执行到哪个线程时才会进入断点

当循环次数>=500时会进入断点,下图可以看到c=499时进入中断模式,因为0-499就是500次。

在断点模式下可以右击红色断点图标继续设置断点条件,达到条件会再次进入断点。右击断点 - 条件,将命中次数设为800

按继续,会发现循环只有在前进到800次时才会进入断点。

操作

下断点后,右击断点,选择"操作",这种调试方式不会进入中断模式,但会将指定的变量输出到输出窗口,输入框可填写由VS提供的变量占位符和你想查看的变量值,当命中断点后会将输入框设置的变量当做文本输出到输出窗口,变量值应填写在{}括号中

$FUNCTION:将当前断点所在的函数的名称作为字符输出
$CALLER:将正在调用当前函数的函数的名称作为字符输出
$ADDRESS:将正在调用当前函数的指令作为字符输出
$CALLSTACK:将正在执行当前函数的堆栈名称作为字符输出
$PID:将正在调用当前函数的进程ID作为字符输出
$PNAME:将正在调用当前函数的进程名称作为字符输出
$TID:将正在调用当前函数的线程ID作为字符输出
$TNAME:将正在调用当前函数的线程名称作为字符输出

如:

可取消勾选继续执行,这样当命中断点后会中断代码的执行,否则不会。输出结果如下图:

调试快捷键

F5:调试的开关(等同于继续按钮),按第一次是执行调试,按第二次是结束调试
F9:为光标所在行下断点
F10:逐过程,即逐条执行,遇到函数时会跳过函数的执行过程直。函数包括了方法、属性、索引器等。但如果为函数体的任何语句下了断点,F10还是会进入函数的断点处。
F11:逐语句,即逐条执行,遇到函数时会进入函数体。
Shift+F11:当按F11逐语句进入了调用函数的内部时,可以按此键位退出当前执行的函数体内部,调到外部

调试类(system.diagnostics)

Debug类和Trace类都提供了静态方法用于调试,区别仅在于Debug只能在调试版本中有效,而Trace类在调试版本或发布版本中都有效。利用这两个类,你可以将感兴趣的变量输出到指定的窗口,这些窗口称为侦听器窗口。当你使用调试时看见的输出窗口就是一个默认的侦听器窗口,而所有的侦听器窗口都从TraceListener派生。

DefaultTraceListener;
//调试模式下的Visualt studio输出窗口
TextWriterTraceListener;
//txt窗口,即一个txt文档
EventLogTraceListener;
//windows事件日志窗口,即windows的事件日志文档
ConsoleTraceListener;
//控制台窗口
XmlWriterTraceListener;
//xml窗口,即一个xml文档

例子

//显示用户列表
public ActionResult Index()
{
    List<UserView> users = new List<UserView>();
    foreach (AppUser user in UserManager.Users)
    {
        users.Add(new UserView { Id = user.Id, Name = user.UserName, Email = user.Email, Password = user.PasswordHash });
    }
    Debug.Listeners.Add( new TextWriterTraceListener( @"E:\logTest.txt" ) );
    Debug.AutoFlush = true; 
    foreach (var u in users)
    {
        Debug.WriteLine( $"用户:{u.Name}" ); //将数据写入所有的侦听器窗口
    }
    Debug.Close( );
    return View(users);
}

调试 - 学习总目录

调试 - Visual Studio调试的更多相关文章

  1. Visual Studio 调试(系列文章)

    调试是软件开发过程中非常重要的一个部分,它具挑战性,但是也有一定的方法和技巧. Visual Studio 调试程序有助于你观察程序的运行时行为并发现问题. 该调试器可用于所有 Visual Stud ...

  2. Visual Studio 调试 ---- 系列文章

    调试是软件开发过程中非常重要的一个部分,它具挑战性,但是也有一定的方法和技巧. Visual Studio 调试程序有助于你观察程序的运行时行为并发现问题. 该调试器可用于所有 Visual Stud ...

  3. 用Visual Studio调试Windows和驱动程序

    由于本人能力有限,翻译不足之处敬请谅解,欢迎批评指正:sunylat@163.com Visual Studio版本:Visual Studio 2015企业版,中文环境. MSDN原文:https: ...

  4. VISUAL STUDIO 调试

    调试术语 Visual Studio调试之断点基础篇 Visual Studio调试之断点进阶篇 不能设置断点的检查步骤 Visual Studio调试之断点技巧篇 Visual Studio调试之断 ...

  5. 用Natvis定制C++对象在Visual Studio调试时如何显示

    博客搬到了fresky.github.io - Dawei XU,请各位看官挪步.最新的一篇是:用Natvis定制C++对象在Visual Studio调试时如何显示.

  6. Visual Studio调试之避免单步跟踪调试模式

    Visual Studio调试之避免单步跟踪调试模式 写完Visual Studio调试之断点进阶篇之后,想分享一下我常用的一些调试技巧,后面发现写之前,一些背景知识需要介绍一下. 下面是几篇今年2月 ...

  7. Visual Studio调试之断点进阶篇

    Visual Studio调试之断点进阶篇 在上一篇文章Visual Studio调试之断点基础篇里面介绍了什么是断点,INT 是Intel系列CPU的一个指令,可以让程序产生一个中断或者异常.程序中 ...

  8. Visual Studio调试之断点基础篇

    Visual Studio调试之断点基础篇 我曾经问过很多人,你一般是怎么调试你的程序的? F9, F5, F11, F…… 有很多书和文章都是介绍怎么使用Visual Studio编写WinForm ...

  9. 在 Visual Studio 调试器中指定符号 (.pdb) 和源文件

    查找并指定符号文件和源文件:指定符号加载行为.使用符号和源服务器上:加载符号自动或在要求.   内容 查找符号 (.pdb) 文件 查找源文件   查找符号 (.pdb) 文件 说明 在之前的 Vis ...

随机推荐

  1. 基于RBAC模型的权限系统设计(Github开源项目)

    RBAC(基于角色的访问控制):英文名称Rose base Access Controller.本博客介绍这种模型的权限系统设计.取消了用户和权限的直接关联,改为通过用户关联角色.角色关联权限的方法来 ...

  2. linux服务器,发现大量TIME_WAIT

    linux服务器,发现大量TIME_WAIT 今天登陆linux服务器,发现大量TIME_WAIT参考资料:http://coolnull.com/3605.html 酷喃|coolnull| » 大 ...

  3. MySQL5.7 的GTID复制

    MySQL5.7 的GTID复制 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 在MySQL5.6之后其官方推出了GTID复制方式,和传统的基于bin log复制方式有所不同,接 ...

  4. 《Apache kafka实战》读书笔记-管理Kafka集群安全之ACL篇

    <Apache kafka实战>读书笔记-管理Kafka集群安全之ACL篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 想必大家能看到这篇博客的小伙伴,估计你对kaf ...

  5. .NET技术-1.0.使用反射、特性简化代码(验证Model类)

    使用反射.特性简化代码 参考项目:利用反射验证Model类/AssemblyVerification 假设现在有一个学生类(Student) /// <summary> /// 学生类 / ...

  6. MAC上截图,编辑图片与恢复图片

    1.Command+shift+3:全屏截图,保存截图到桌面 2.Command+shift+4:鼠标选定区域截图,保存截图到桌面 3.Command+shift+4+Space(空格键):程序窗口截 ...

  7. keytool导入导出多条目对比【原】

    步骤一:生成orange.keystore和banana.keystore keytool -genkey -alias orange -keyalg RSA -keysize 1024 -keypa ...

  8. jquery中$.post()方法的简单实例

    在jqery中有这样一个方法,$.post()下面就这个方法做一个简单的实例: jQuery.post( url, [data], [callback], [type] ) :使用POST方式来进行异 ...

  9. javaScript ES5常考面试题总结

    js的六种原始值 boolean null undefined number string symbol 坑1: 首先原始类型存储的都是值,是没有函数可以调用的,比如 undefined.toStri ...

  10. Vertica系列:从一些细节看Vertica为什么是一个优秀的数据仓库平台

    ===========================================对象名称可以长到128字符===========================================1 ...