在系统中异常或者崩溃的时候,来生成dump文件,然后用调试器来调试,可以快速精确定位崩溃的代码行。
这样就可以把生产环境中的dmp文件,拷贝到自己的开发机器上,调试就可以找到错误的位置,配合程序调试符号pdb文件,直接可以定位到源代码中位置,真是太神奇了。
1.创建dump文件的三种方法:
第一种:通过任务管理器:这种适用在程序挂了(crash)的时候进程还未退出,比如我运行程序,出现了下面的错:
此时打开任务管理器,右击相应进程,点击"Create Dump File“:
一会创建完成:
第二种:改注册表
如果程序crash的时候没有框蹦出来,可以通过改注册表的设置让操作系统在程序crash的时候自动生成dump,并放到特定的目录下
其中Value Data=1代表的含义是:
设置完成后,crash发生时,操作系统生成dump,路径在%LOCALAPPDATA%\CrashDumps下。
第三种:程序生成SetUnhandledExceptionFilter + Minidump
在这里不做详细介绍了,有兴趣参考:
http://blog.youkuaiyun.com/byxdaz/article/details/25872151
2.使用dump文件
将创建的DMP文件拷到开发机器上后,用VS打开: 会出现下面的界面,要想知道发生错误时候的调用栈,需要设置symbol的路径,点击”Set Symbol Paths“:
注意这个pdb要对应于crash的exe的pdb文件,否则调用栈没法显示:
设置好所有该设置的路径后,点击”Debug with Native Only“就可以看到调用栈了。
Get新技能了吗?赶紧试试吧
参考文章:
http://blog.youkuaiyun.com/byxdaz/article/details/25872151
http://blog.youkuaiyun.com/jfkidear/article/details/22201829
http://blog.youkuaiyun.com/chinabinlang/article/details/49491813