PDB不一致

一、pdb文件简介

英文:Program Data Base,即程序的基本数据,是VS编译链接时生成的文件。

pdb文件主要存储了如下调试信息:

(1)public, private,和static函数地址。

(2)全局变量的名称和地址。

(3)参数和局部变量的名称及它们在栈中的偏移量。

(4)类型定义,包括class, structure,和 data definitions。

(5)源文件名称和行号。

二、exe、dll和pdb匹配问题

1、调试时,系统会查找exe或者dll中指定位置的pdb文件,并且会跟踪exe或者dll中pdb的校验码GUID来对现有的pdb文件进行版本校验。这里需要知道,即使源码没有做任何更改,该pdb文件对应的校验码也是不同的。

2、查找exe或者dll中的GUID的值,方法如下:

(1)在开始菜单中“Visual Studio 命令行提示(2010)”中输入:dumpbin /headers {exe绝对路径},如下图所示:

(2)回车之后,结果如下:

PDB不一致_第1张图片

(3)红色方框位置就是pdb文件校验码和路径。

(4)下图是vs2010执行“重新生成解决方案”之后,获取exe中的pdb文件校验码。

可以发现,前后两个校验码是不一样的。

(5)但是,当我任何代码没有改的情况下,我单击vs2010下的“生成解决方案”功能,GUID的值如下:

可以发现前后二者的值是一样的。

三、总结

1、调试时,要保证exe和pdb文件同时生成。

2、若之前的pdb文件丢失,则单击“生成解决方案”亦可挽回,前提是不要更改任何代码。目前高版本(实验环境VS2017)即使代码未改变,生成解决方案二次PDB的GUID也会发生变化。

 

四、拓展

GUID:Globally Unique Identifier,全球统一标识符。是一种由算法生成的二进制长度为128位的数字标识符。

 

五. PDB文件查找路径

1. PE文件的相同路径

2. PE文件中调试目录表中的调试数据文件地址所在的目录

3. 调试缓存目录(VS2017缓存好像未找到)

3. 调试过程中设置的调试符号的路径(VS2017下需要手动选择加载)

 

六. 源文件路径

 与PDB文件同理

你可能感兴趣的:(调试)