IntelliTrace调试
当您进行调试时,IntelliTrace 将在后台收集有关托管应用程序的数据,其中包括来自许多框架组件(例如 ADO.NET、ASP.NET 和 System.XML)的信息。这些 IntelliTrace 事件使开发人员能够查看先前在执行过程中发生的情况,并且最重要的是,能够进行“回溯”以查看应用程序的先前状态,而不必重新启动调试器。当我进入调试器时,我立即看到了按顺序列出的以前收集的 IntelliTrace 事件, IntelliTrace窗口允许按类别或按线程对所收集事件的列表进行筛选。此外,我可以执行基于文本的搜索来查找可快速跳转到的重要事件。由于 IntelliTrace 还会收集异常,因此我可以搜索词条“异常”,列表将进行筛选以列出导致出现 ASP.NET 错误页的异常,既包括在其中引发的异常调出IntelliTrace窗口快捷键Ctrl+D,V
1、默认设置为 仅收集事件(如图1),在 工具--选项-IntelliTrace中可以修改设置
默认情况下,IntelliTrace 配置为仅收集 IntelliTrace 事件。此解决方案开销很低,但不会提供应用程序的完整执行历史记录。如果您需要更深层的信息,则可以配置 IntelliTrace 来收集更多数据。像其他调试器设置一样,IntelliTrace 也可通过“选项”对话框(可从“工具”菜单中访问)进行配置(请参见图 1)。
图1 默认设置
| 类别 | 描述和收集的数据 |
| ADO.NET | 与针对 SQL 执行查询、执行的命令以及连接字符串相关的事件。 |
| MVC | 与 ASP.NET 管道以及请求处理和重定向相关的事件。 |
| 控制台 | 控制台输出。 |
| 数据绑定 | Windows 窗体数据绑定。 |
| 环境变量 | 对进程中的环境变量进行求值和检索。 |
| 文件 | 创建、删除和访问文件。 |
| 手势/ 特定动作 | 用户对 Web 窗体、Windows 窗体和 WPF 中的常见控件执行的操作。除了收集有关与控件的交互的数据之外,单击其中一个事件还会自动将您重定向到相应的事件处理程序。 |
| 迟缓初始化 | 初始化延迟加载的变量。 |
| 注册表 | 创建、删除和查询注册表信息。 |
| 服务模型 | 从 WCF 中进行的 Web 服务调用。 |
| 线程处理 | 用户工作项和并行计算任务的排队。 |
| 跟踪 | 调试器跟踪输出和断言。 |
| 用户提示 | 显示 Windows 窗体和 WPF 消息框以及对话框的结果。 |
| 工作流 | 实例化和完成活动。 |
| XML | XML 文件加载。 |
图 2 重点列出了一些 IntelliTrace 所收集事件的类别。
使用例子,在datagirdview中加载数据:
private void Form1_Load(object sender, EventArgs e) { dgvList.Rows.Clear(); List<Model.m_Car> lst = new BLL.m_Car().GetModelList("i_Flag=0"); foreach (Model.m_Car item in lst) { int i = dgvList.Rows.Add(item.vc_name, item.vc_remark); dgvList.Rows[i].Tag = item; } dgvList.ClearSelection(); //此处加断点 }
点击要查看的事件,会看到详细信息(图3),并在局部变量(图4)和调用堆栈(图5)中显示信息
图3 智能跟踪窗口(查看数据库访问事件)
图4 局部变量(显示sql语句,数据库连接信息)
图5 调用堆栈(点击相应的调用命令,会定位到源代码中,但是此处没收集调用信息,所以strWhere是未知的)
2、收集事件及调用信息
通过选择“IntelliTrace 事件和调用信息”,可将 IntelliTrace 配置为不仅收集 IntelliTrace 事件,而且在每个方法进入、退出和调用站点时收集调用信息,例如位于这些位置的参数和返回值。
由于存在性能问题,因此默认情况下只会为集合启用定义的 IntelliTrace 事件的一个子集。您可能需要考虑启用的某些事件包括控制台输出、文件访问、迟缓初始化、注册表访问以及线程处理事件。您可以从“选项”对话框的“IntelliTrace 事件”窗格中启用或禁用整个事件类别或个别事件。
图6 收集事件及调用信息,可以回放调用历史
2.1 事件视图,调用视图
还是刚才的例子,启动调试,智能跟踪窗口如图7,和图3不同的是,智能跟踪窗口顶端有《切换到调用视图的按钮》
图7 智能跟踪窗口
点击切换后如图8,显示调用历史信息,通过浏览“调用”视图这种机制,可以快速了解执行历史记录的概况,并在代码库中进行大幅跳转。
图8 调用历史信息
2.2 单步回放历史执行记录控件
在源代码窗口的装订线中会出现这样的控件,能够单步执行应用程序,并且在局部变量窗口看到每一步值的变化
图9
图10
图11 也可以通过点击《在此设置调试上下午》,出现图9的控件,执行单步调试
2.3 在 IntelliTrace 中搜索此行, 搜索功能使我能够恰好跳转到特定的函数调用
在编辑器中,我可以右键单击要搜寻的行,并从上下文菜单中选择“在 IntelliTrace 中搜索此行”(请参见图 12)。搜索将开始,并且结果将呈现在编辑器窗口顶部的搜索栏中,请参见图 13)。
图12 搜索功能使我能够恰好跳转到特定的函数调用
图13
参见
http://msdn.microsoft.com/zh-cn/magazine/ee336126.aspx
http://msdn.microsoft.com/zh-cn/library/dd572114.aspx
http://msdn.microsoft.com/zh-cn/library/dd264963.aspx#Open
IntelliTrace调试的更多相关文章
- IntelliTrace 调试、定位异常
最近看了一个开源数据库管理,然后没有认真看它的配置环境,想看看是什么东西, 然后发现有类型转换的错误,但是一下子也定位不到哪里出错? 所以对于这种一下子找不到异常在哪里的,可以使用intellitra ...
- 使用 IntelliTrace 调试应用程序
IntelliTrace 如何能够大幅改善您的日常开发活动,并提升您快速轻松诊断问题的能力,而不必重新启动应用程序和使用传统的“中断-单步执行-检查”技术进行调试.介绍了组织如何能够通过在测试过程中收 ...
- 掌握VS2010调试 -- 入门指南
1 导言 在软件开发周期中,测试和修正缺陷(defect,defect与bug的区别:Bug是缺陷的一种表现形式,而一个缺陷是可以引起多种Bug的)的时间远多于写代码的时间.通常,debug是指发现缺 ...
- VS2010调试入门指南
1 导言 在软件开发周期中,测试和修正缺陷(defect,defect与bug的区别:Bug是缺陷的一种表现形式,而一个缺陷是可以引起多种Bug的)的时间远多于写代码的时间.通常,debug是指发现缺 ...
- VS2010调试 --指南 Reference from : http://blog.csdn.net/kingzone_2008/article/details/8133048
1 导言 在软件开发周期中,测试和修正缺陷(defect,defect与bug的区别:Bug是缺陷的一种表现形式,而一个缺陷是可以引起多种Bug的) 的时间远多于写代码的时间.通常,debug是指发现 ...
- [转载]基于TFS实践敏捷-Scrum模式运用
根据Forrester Research今年第二季度的一份研究报告,在超过1000名专业开发人员中,采用敏捷模式进行软件开发的已经有10.9%采用了Scrum模式,在所有的敏捷开发模式中名列首位,而在 ...
- 一些有用的Azure工具
目前,Azure 没有为客户提供监控和管理托管服务的完整解决方案.为了获取网络信息,speedtest.net 提供了一种工具,用于测量响应时间.带宽和整体连接质量.可以使用 Matthew Roso ...
- [转]基于Visual Studio 2010 进行敏捷/Scrum模式开发
http://www.infoq.com/cn/articles/visual-studio-2010-agile-scrum-development 根据Forrester Research今年第二 ...
- Visual Studio 调试系列4 单步后退来检查旧应用状态(使用使用 IntelliTrace 窗口)
系列目录 [已更新最新开发文章,点击查看详细] IntelliTrace 后退会在每个断点处及调试器步骤事件发生时自动拍摄应用程序的快照. 凭借记录的快照便可以返回到上一个断点或步骤,并查看当 ...
随机推荐
- jmeter正则表达式提取
使用jmeter正则表达式提取器之前,首先 使用httpwatch 分析一下 我要要测试的系统正则管理的规则: 例如:我这里要关联的是一个ODS数据仓库平台的登录 1./sso/login..单点登录 ...
- nginx调优buffer参数设置
内容来自 https://blog.tanteng.me/2016/03/nginx-buffer-params/.有空再详细了解 Nginx性能调优之buffer参数设置 打开Nginx的error ...
- 双三次插值C代码(利用opencv)
双三次插值C代码(利用opencv) phasecubic2.cpp D:\文件及下载相关\文档\Visual Studio 2010\Projects\phasecubic2\phasecubic2 ...
- centos7 ngxin启动失败:Job for nginx.service failed(80端口被占用的解决办法)
问题描述:(flaskApi) [root@67 flaskDemo]# service nginx start Redirecting to /bin/systemctl start nginx.s ...
- Python学习之==>常用字符串方法
1.常用字符串方法 a = '\n 字 符 串 \n\n' b = a.strip() # 默认去掉字符串两边的空格和换行符 c = a.lstrip() # 默认去掉字符串左边的空格和换行符 d = ...
- anr以及nlp语音自动化测试方案
进行asr自动化测试 1.将人工语音录制的音频文件分为一句话一个文件,并将文件名命名为此句话,可以加后缀,例如:附近的公园_1 2.使用电脑连接蓝牙音箱,控制好距离角度等环境 3.使用python或者 ...
- 【ABAP系列】SAP ABAP 从FTP服务器读取文件到本地
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP 从FTP服务器 ...
- spring cloud gateway自定义过滤器
在API网关spring cloud gateway和负载均衡框架ribbon实战文章中,主要实现网关与负载均衡等基本功能,详见代码.本节内容将继续围绕此代码展开,主要讲解spring cloud g ...
- (二)inlineCallbacks,同步方式写异步代码
一. 上篇提到了用defered对象注册回调的方式,来处理异步操作,这样大家都知道,实际情况代码很难搞的.因为当业务逻辑复杂后,这边一个异步操作,我们注册一个回调,代码跳到A地方,A里面也有异步操作, ...
- Servlet,HttpServletRequest 和 HttpServletResponse
今天是周六,老子加班,还可吧, 哈哈哈哈哈哈哈哈哈哈哈哈哈 此次更新的内容是HttpServletRequest 和 HttpServletResponse 昨天复习了一部分内容,今天又把剩下的看完. ...