该文章参考网上内容,加上一些些自己的使用经验。
Ø 配置符号路径
WinDbg主菜单——File——Symbol Search Path
输入框中的输入规则如下:
1)配置程序对应symbol文件的路径
2)多个路径之间使用分号隔开
3)配置微软符号文件的路径:
srv*"D:\Symbols"*http://msdl.microsoft.com/download/symbols
"srv"符号服务器的标识
"D:\Symbols"本地缓存路径,windbg会将使用到的符号文件下载存放在该目录,并在下次执行时,优先寻找该目录
" http://msdl.microsoft.com/download/symbols"符号服务器地址,该地址为微软符号服务器地址
4)微软符号地址离线下载地址:
"http://msdn.microsoft.com/en-us/windows/hardware/gg463028.aspx"
5)当前程序的符号需要在编译器设置编译过程中生成符号文件,VC6.0需要配置,配置方式为:项目设置——链接——常规——勾选“产生调试信息”,(本人现用汉化版,英文版设置方法相同)
Ø 配置源码位置
1)主菜单——FILE——Source Search Path
2)多个源码路径使用分号隔开
3)使用源码调试,必须设置编译器在编译的过程中禁用优化。(现在没有发现其它办法,因此感觉源码调试在CrashDump分析中,用处不是很大,,待学习中)
Ø 相关指令
操作指令 |
|
!analyze -v |
自动对.dmp做基本的分析 |
.ecxr |
检查EXCEPTION_RECORD |
Symbol命令 |
|
ld module |
加载pdb |
.reload /f |
强制加载所有模块 |
lm |
查看已加载的模块列表 |
x module!symbol |
查询指定名称的symbol |
ln address |
显示指定地址对应的symbol |
执行流程分析 |
|
~0s |
切换线程 |
kb/kv/k.. |
显示调用堆栈 |
u/ub/uf |
反汇编代码 |
dds |
查看一段地址中的数据,并显示其对应的symbol |
|
|
数据分析 |
|
r |
查看/修改寄存器 |
? |
计算表达式的值 |
.expr |
表达式切换 |
db/dd/du/da |
显示内存中的数据:分别按照byte/dowd/unicode string/ansi string |
dv |
显示局部变量列表 |
dt |
显示指定symbol的结构 |
|
|
分析效果图:
报错代码截图:
WinDbg分析情况截图: