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. C语言进阶——Day 1

    C语言提高笔记 Day 1 小数据赋给大变量,首位是1则在前面自动补充1,首位是0则在前方自动补充0. 大数据赋给小变量,低位字节对齐,truncate截断,有可能会造成数据丢失. 程序和进程的差别: ...

  2. 跨域、curl、snoopy、file_get_contents()

    定义:可以称为”信息采集/模拟登录”技术,可以实现对某个地址做请求,同时按照要求传递get或post参数. curl本身是php的一个扩展,同时也是一个利用URL语法规定来传输文件和数据的工具,支持很 ...

  3. bzoj1040 基环树森林dp

    https://www.lydsy.com/JudgeOnline/problem.php?id=1040 Z国的骑士团是一个很有势力的组织,帮会中汇聚了来自各地的精英.他们劫富济贫,惩恶扬善,受到社 ...

  4. CodeForces755F 贪心 + 多重背包二进制优化

    https://cn.vjudge.net/problem/615831/origin 题意 n个人;  计划是每个人都拿一个礼物来送给一个除了自己之外的人;  如果一个人没有送出礼物,那么它和它送礼 ...

  5. python机器学习-sklearn挖掘乳腺癌细胞(五)

    python机器学习-sklearn挖掘乳腺癌细胞( 博主亲自录制) 网易云观看地址 https://study.163.com/course/introduction.htm?courseId=10 ...

  6. Tensorflow做阅读理解与完形填空

    catalogue . 前言 . 使用的数据集 . 数据预处理 . 训练 . 测试模型运行结果: 进行实际完形填空 0. 前言 开始写这篇文章的时候是晚上12点,突然想到几点新的理解,赶紧记下来.我们 ...

  7. 11、JDBC-Druid

    依赖 pom.xml <?xml version="1.0" encoding="UTF-8"?> <project xmlns=" ...

  8. 3.Zuul-过滤器

    1.什么是Zuul? 路由+过滤器=Zuul,核心是一系列的过滤器 2.Zuul的过滤器: pre:可以在请求被路由之前调用 route:在路由请求时候被调用 post:在route和error过滤器 ...

  9. web.xml之<context-param>与<init-param>的区别与作用【转】

    引用自-->http://www.cnblogs.com/hzj-/articles/1689836.html <context-param>的作用:web.xml的配置中<c ...

  10. Linux下main函数启动过程【程序员自我修养笔记】【自用】

    1. 入口函数和程序初始化 1.1 程序从main开始吗? 当程序执行到main函数的第一行时,很多事情都已经完成了: [证1]如下是一段C语言代码: 代码中可以看到,在程序刚刚执行到main的时候, ...