.NET程序调试技巧(一):快速定位异常的一些方法

   这篇文章主要介绍了.NET程序调试技巧(一):快速定位异常的一些方法,本文讲解了定位本机异常、在客户环境定位.net程序异常两方面的内容,需要的朋友可以参考下

  作为一个程序员,解BUG是我们工作中常做的工作,甚至可以说解决问题能力是一个人工作能力的重要体现。因为这体现了一个程序员的技术水平、技术深度、经验等等。

  那么在我们解决BUG的过程中,定位问题是非常重要的。有句话叫"发现问题是解决问题的一半。

  本文讲述就快速定位异常(专指.NET程序异常)的方法。包括在本机定位异常,在客户环境定位.net程序异常,在客户环境定位SilverLight异常。

  一:定位本机异常

  在我们本机定位异常很容易。假设我们都是使用的的VisualStudio,那么只需要在调试->异常菜单中将Common Langeuage Runtime Exception(CLR异常)勾选。如下图:


  在上面的图片中可以发现有5种类型的异常,例如c++异常、win32异常等等。对于.NET程序来说我们只关注CLR异常。

  接下来进行调试,当自己的程序代码中有异常的时候,VS就会自动定位到异常的位置。

  我们可以看到异常的详细信息,并且可在调用堆栈窗口中看到 程序的堆栈信息。在堆栈信息中我们可以看到在哪个类、哪个函数中出的错,如下图:


  调试程序有两种方式,一种是用VS直接启动程序,另一种是附加到进程。


  附加到进程的时候,程序类型不要选错了,我使用的是.net4.0 所以程序类型选择的是 托管(4.0版)代码。

  另外附加到进程有个快捷键是 Ctrl+Alt+P。

  但是如果异常不是你的代码中抛出的,那么如何定位呢?

  可以打开 调试 菜单下面的 选项和设置,将 启用"仅我的代码" 这一项取消勾选。那么别人代码中的异常就可以抛出了。


  二:在客户环境定位 .net 程序异常:

  我们的程序最后都会运行在客户的环境中,客户环境上不会有VS这样的开发工具,那么怎么办呢?

  我们可以使用一个很小巧的命令行调试工具Mdbg.exe,这个工具是安装VS的时候附带安装的,仅能调试.net托管代码。

  Mdbg.exe其实有很多功能,不过本文只讲它定位异常的功能,后续文章会讲使用Mdbg.exe单步调试的方法。

  Mdbg.exe命令详细介绍可以 输入 h(help) 或者? 名来查看,也可以看下面的链接,

  http://msdn.microsoft.com/zh-cn/ms229861(vs.80).aspx#

  根据CLR版本的不用,Mdbg.exe也是有多个版本的。

  C:Program Files (x86)Microsoft SDKsWindowsv7.0ABinMdbg.exe用于调试

  CLR2.0(对应net2.0,3.0,3.5)程序。

  C:Program Files (x86)Microsoft SDKsWindowsv7.0ABinNETFX 4.0 ToolsMdbg.exe用于调试CLR4.0程序(对用.net4.0)。

  另外Mdbg.exe有一个依赖DLL 叫做MdbgCore.dll。我们可以直接将相应版本的Mdbg.exe和MdbgCore.dll拷贝到客户机器上使用。

  没有安装VS的朋友可以拷贝我自己封装的一个安装包 http://xiazai.jb51.net/201506/other/U8DebugSetup.rar,这里面除了Mdbg.exe还有一些其他组件我们后面的文章会用到。

  默认会安装在 C:Program FilesU8Debug。

  Mdbg.exe的使用方法很加简,双击打开它,然后输入 a(attach , 显示附加的进程),回车,这时会列表所有可以附加的进程。


  PID 表示进程标识,

  输入a 11940 附件到 ConsoleApplication2.ex示例程序。

  这时程序会中断执行,我们在这个时机可以做一些设置。让程序在遇到异常时自动中断。

  输入命令 ca (catch)查看当前调试器遇到哪些事件会中断。


  可以看到 Exception对应的是Igonre all exception ,也就是忽略所有异常,发生异常时不会中断。

  输入命令 ca ex 这样调试器遇到异常时就会中断了。

  再次输入ca 命令会看到 Exception对应的值已经变为Stop on all exception了。这时遇到任何异常都会中断了。


  输入命令 g 让程序继续执行。

  当遇到异常时会自动中断到调试器,如下图:


  入命令 w(where,程序运行到哪里了) 可以查看异常堆栈信息


  三:在客户环境定位SilverLight异常

  如果客户的silverlight应用服务器部署在外网,那么我们可以直接用浏览器访问该silverlight站点,然后用VS附加到浏览器进程来调试。


  调试方法比调试普通.net程序一样。

  但是如果,客户的Silverlight服务器是部署在内网,那么你只能在客户机器上调试了。

  并且Mdbg.exe也帮不了你了,它不能调试Silverlight程序。

  我们还有另一个著名的调试工具Windbg。体积大概有不到20M,很容易安装到客户机,安装包大家可以到网上自己下载。windbg分为32位和64位两个版本,

  调试32位的程序请使用32位windbg,反之则要使用64位的windbg,具体为什么我们不用深究,记住了就可以了。

  相比Mdbg.exe的小巧实用,Windbg显然强大的多,但是使用起来也复杂一些。

  Windbg其实可以调试很多种类型的程序,例如普通.NET程序,c++等。但是本文只讲解使用windbg定位异常的方法。

  首先我们使用IE浏览器打开silverlight应用程序,然后打开windbg附件到IE进程来调试。附加进程的方式可以通过File菜单下的Attach to a process或者使用F6快捷键。


  附件进程后 程序会中断到调试器,这个时候我们需要做两个设置。

  一个是 设置程序发生异常时让其中断到调试器,设置方法是打开debug菜单下的Event Filter,将CLR异常设置其为enable。


  另外需要加载调试器扩展,使用过windbg的朋友都知道调试.net程序需要加载一个调试器扩展sos.dll。这个sos.dll也有一个Silverlight版本的。

  位置在silverlight的安装目录 C:Program Files (x86)Microsoft Silverlight5.1.10411.0sos.dll。

  我们再command窗口中输入 .load C:Program Files (x86)Microsoft Silverlight5.1.10411.0sos.dll 来加载它。

  之后输入命令 g 来回复程序的执行。当发生异常时就会中断到调试器中。

  发生异常是我们可以使用!pe(print exception) 来查看异常信息。如下图:


  如果想查看堆栈信息的话可以输入命令 !clrstack


  通过上述方法基本可以定位所有的.NET异常。至此,本文结束。

时间: 2024-09-12 18:35:45

.NET程序调试技巧(一):快速定位异常的一些方法的相关文章

.NET程序调试技巧(一):快速定位异常的一些方法_实用技巧

作为一个程序员,解BUG是我们工作中常做的工作,甚至可以说解决问题能力是一个人工作能力的重要体现.因为这体现了一个程序员的技术水平.技术深度.经验等等. 那么在我们解决BUG的过程中,定位问题是非常重要的.有句话叫"发现问题是解决问题的一半. 本文讲述就快速定位异常(专指.NET程序异常)的方法.包括在本机定位异常,在客户环境定位.net程序异常,在客户环境定位SilverLight异常. 一:定位本机异常 在我们本机定位异常很容易.假设我们都是使用的的VisualStudio,那么只需要在调试

在Word长文档中快速定位指定信息的方法

在Word长文档中快速定位指定信息的方法 1.打开Word文档,在"开始"选项卡"编辑"选项组中,单击[查找]按钮右侧的下三角按钮( ),在随即打开的下拉列表中执行[转到]命令,打开"查找和替换"对话框,如图1所示.或者也可以使用[Ctrl]+[G]组合键打开该对话框. 图1 打开"查找和替换"对话框 2.在"定位"选项卡左侧的"定位目标"列表框中选择"页",在右侧&

Excel2007快速定位指定工作表方法

  平常我们总是习惯于在同一个Excel文档中设计大量表格.工作表标签栏一次最多也就显示五六个工作表名称,即不能排序又不支持查找功能.想直接在标签栏中按名称找工作表可不简单,单是翻页就够你眼睛花的.在此为大家介绍两种在Excel 2007中轻松找到指定工作表的方法. 借助工作表列表 在Excel中本来就有一个提供全部工作表的名称列表,在列表中就可以轻松找到并切换到指定的工作表. 1.显示列表 在工作表标签栏左侧有四个控制标签滚动.翻页的按钮,在此处右击就会弹出一个列表显示当前文档中所有工作表名称

PHP程序百行代码快速构建简易聊天室方法

 基本功能:能登陆,聊天,记录在线人数IP事件,能控制聊天的字体颜色,自动把转化聊天中网址为链接地址,能定制聊天室标题.广告信息等等.使用文本作为存储媒体,又兴趣可以参考代码,并且进行扩展. 其实PHP作为快速开发的脚本语言是很棒的! ===代码=== 以下为引用的内容:  <?php /**  * 黑夜路人简易聊天室  * 作者: heiyeluren <heiyeluren_at_163.com>  * 创建: 2005-8-10 22:42  * 修改: 2005-8-11 23:

javascript 调试: javascript调试技巧之:快速定位

赶紧总结一下javascript的调试技巧,这次首先是"快速定位"篇.快速定位,其实就是快速定位程序的错误,所以也算是调试.这个在实际的码代码时往往比较实用.大多数情况下,你的js代码不多(少于1000行),只要能迅速发现代码的错误,往往不用复杂的调试.关于常用的快速定位方法,我总结了一下几点,欢迎大家补充.1. 使用alertalert其实比较实用.本地调试中,在合适的位置写alert,打出来一些变量,虽然比较土,但是往往事半功倍!另外有一个alert技巧,想看看一个对象中的属性和它

调试技巧 —— 如何利用windbg + dump + map分析程序异常

之前碰到论坛里有几个好友,说程序不时的崩溃,什么xxoo不能read的! 如果光要是这个内存地址,估计你会疯掉~~ 所以分享一下基本的调试技巧,需要准备的工具有WinDbg + VC6.0, 下面是自己整理的一份自动生成DUMP文件的源代码,只需要添加到工程即可,源代码如下: MiniDump.h   [cpp] view plaincopyprint?   #include <windows.h>   #include <tlhelp32.h>      //#include &

快速定位windows8收藏夹位置的技巧

  在使用IE浏览器时,一般保存网站网址都会存储在默认的收藏夹里,以便轻松访问.在windows其他系统下,用户都能很快地找到收藏夹的位置,但是在新系统windows8下,由于改变了全新的风格,一时之下,用户很难找到收藏夹位置,下面就教大家一个小方法,快速定位windows8收藏夹位置. 1.按"Win键"+"E"进入"计算机",双击打开系统盘"C盘" 2.找到"用户"文件夹(某些系统会显示为"U

Atlas应用程序的调试技巧

程序|技巧 "Atlas"程序由服务器端代码和客户端代码组成,并且,浏览器可能会要去异步请求一些数据.那么,怎样才能Debug这样的web程序呢.本文将告诉你如何使用一些技术和工具来方便的完成这件事. 注: 除了Visual Studio和Internet Explorer,本文提及的程序是一些第三方的,微软不会提供支持的.请到这些工具的主页去阅读授权和支持信息. 为了更好的Debug,先对应用程序进行配置 要启用VS的Debug功能,请添加一个<compilation>元

使用微信小程序开发前端【快速入门】_javascript技巧

前言 2016年9月22日凌晨,微信官方通过"微信公开课"公众号发布了关于微信小程序(微信应用号)的内测通知.整个朋友圈瞬间便像炸开了锅似的,各种揣测.介绍性文章在一夜里诞生.而真正收到内测邀请的公众号据说只有200个. 虽然内测名额十分稀少,但依赖中国广大开发者的破解和分享精神,在网络上很快出现了开发工具的破解版本和API文档.然而可能是微信的妥协或者早已预料,9月24日微信官方发布了不需要破解就可以使用的微信小程序开发者工具和文档,对于费劲心思破解完的开发者来说应该瞬间整个人都不好