VC调试笔记
1、windows-32调试:
①使用map文件根据崩溃地址寻找对应的源代码文件和行号
勾选project->settings->link->General mapfile,对应的Project Options中添加:/MAPINFO:LINES /MAPINFO:EXPORTS 。 在不使用优化且没有多dll引用导致的重定向时,崩溃地址寻找对应的代码行的方法:崩溃地址=装载机地址(0x10000000)+PE头文件大小(0x00001000)+RVA值,这个RVA值在生成的map文件中形如“
Line numbers for .\Debug\KillerDLL.obj(C:\Users\Administrator\Desktop\WindowDebug2\KillerDLL\KillerDLL.cpp) segment .text
13 0001:00000030 14 0001:00000048 15 0001:0000004d 19 0001:00000060
21 0001:00000082 24 0001:000000a0 25 0001:000000b8 27 0001:000000c6
29 0001:000000e4 30 0001:000000ec 33 0001:000000ee 34 0001:00000103
37 0001:00000105 38 0001:0000010c 39 0001:00000116 43 0001:00000118
44 0001:00000128 45 0001:0000012f 48 0001:00000138
”
内冒号右边的值时,对应最左边的即为对应行号
②使用PDB文件找对应的源代码文件和行号
打开反汇编窗口,Edit->goto->address即可找到对应的汇编代码,右键,goto source即可找到源文件和行号
③使用Dr.Watson调试:C:\Windows\System32\DRWATSON.EXE (未完)
双击会在Windows目录生成drwatson.log文件,监控可能报错的程序
在活跃(active)函数里增加新的变量时,还有个总的变量长度不超过64字节的限制
PerformTimeConsumingDebugCheck();//这函数的具体意思?