软件崩溃是大多数软件都不能避免的问题,通常情况下,软件会设计上传dmp文件的机制,用户的错误堆栈会提供给软件开发商,从而能够帮助开发者定位问题。
Visual Studio提供了强大的dmp调试方法,只要能够提供对应的符号文件,VS就可以帮助开发者将问题定位到具体的崩溃位置,并且复现堆栈。操作方法如下:
(1)新建复现堆栈项目:双击dmp或者将dmp拖入到空vs中打开dmp文件;
(2)加载后,会显示一个dmp的基本信息,包括异常信息,报错位置等。
这时候可以进入调试状态:点击右上角的“仅限本机”进行调试
(3)进入调试状态后,会复现堆栈,首先系统会提示当时崩溃的信息,然后进入断点(堆栈的断点不一定是真正崩溃的位置)。要浏览崩溃堆栈,需要给代码加载符号。打开VS的调试下模块窗口,查看程序依赖的模块,并给相关的模块以此增加依赖的pdb文件(符号文件)
同一地址下的pdb文件只需要添加以此路径,不过需要每个dll都进行以此选择符号文件路径的操作。
将所有依赖的pdb全部加载之后,堆栈就基本上能够看到我们需要的信息了!
(4)堆栈信息加载之后基本可以判断整个运行的流程,不过如果想看当时的变量值的话,只加载符号文件还不足以应对,需要加载源码进行调试:调试方法:
右键堆栈的函数,选择转到源代码,然后在路径中选择源码,即可显示出源码窗口。
至此,通过dmp复现堆栈就完成了。不过对于部分dmp来说,有时候并不能通过VS有效进行调试,这时候windbg要比VS发挥出更稳定的性能(一个无法用VS定位堆栈的dmp使用为windbg能够清楚定位位置),不过VS的窗口化操作还是更加方便的。