当前位置: 首页 > news >正文

PDB文件详解

PDB文件的介绍

PDB(Program Data Base),意即程序的基本数据,是VS编译链接时生成的文件。DPB文件主要存储了VS调试程序时所需要的基本信息,主要包括源文件名、变量名、函数名、FPO(帧指针)、对应的行号等等。因为存储的是调试信息,所以一般情况下PDB文件是在Debug模式下才会生成

PDB文件的调用过程

模块(Module),EXE和DLL都可以称之为模块,因为它们都有自已独立的Stack,所以我们在调试程序时,可以在Call Stack窗口查看到所有调用的Module Name。并且可以右键查看相应模块的sybmol Load Information,即该模块调用的PDB文件路径的过程。

每个模块被载入的时候,其相同名字的PDB文件同时被载入。所以Debug模式下,不仅因为代码没有优化,同时因为要载入PDB文件,所以Debug模式下的程序执行速度非常慢。

每个模块只会生成一个相同名字的PDB文件,并且模块生成的同时,会校验PDB文件生成GUID记录在模块内。这是因为调试时,调试器强制要求每个模块必须和PDB文件保持一致。实验过程中,用之前生成的PDB文件替换当前生成的PDB文件时,Debug窗口会显示No symbols loaded. MSDN也做了相应的说明:The debugger will load only a PDB for a binary that exactly matches the PDB that was created when the binary was built.

PDB文件中记录了源文件路径的相关信息,所以在载入PDB文件的时候,就可以将相关调试信息与源码对应。这样可以可视化的实时查看调试时的函数调用、变量值等相关信息。模块当中记录的PDB文件是绝对路径。所以只要模块在当前电脑上载入,调试器自然地会根据模块当中的路径信息找到相应PDB文件并载入。同样PDB文件中记录的源文件路径也是绝对路径,所以PDB文件只要在当前电脑上载入,调试进入相应模块时,都能够匹配到记录的源文件,然后可视化地查看相应信息。

如果源文件找不到,那么依然能够查看调试信息,只是这个时候只能查看汇编代码,不能通过源文件可视化查看信息。一般情况下,绝大多数C++程序员不具备阅读汇编代码的能力。所以完全通过PDB文件调试,意义与作用均没有多大。如果要让其他人能够调试自已的代码,PDB文件和源码都应该提供,只提供PDB文件的意义不大。如果确实有类似的需求,可以保留相应生成的PDB文件。微软的很多库默认是不提供PDB文件的,但是近来微软逐渐开放了一些库的PDB文件。

VS搜索PDB文件的路径顺序

MSDN中详细的讲述:

1. The Visual Studio debugger uses the path to the PDB in the EXE or DLL file to find the project.PDB file.

2. If the debugger cannot find the PDB file at that location or if the path is invalid (for example, if the project was moved to another computer), the debugger searches the path containing the EXE.

3. the symbol paths specified in the Options dialog box (Debugging folder, Symbols node).

1是默认当前路径,2是编译链接时记录在模块当中的路径。现在重点说3,即设置符号文件路径。

通过Options->Debuggin->Symbols或在Call Stack窗口右键找到Symbol Settings打开下面的窗口。

我将PDF的生成路径调整到D:\,调试时将PFB文件剪切到D:\Other目录。

然后调试进入dll模块时,右键在Call Stack对应的Module上选择查看Symbol Load Information.

通过上图即可以看到VS加载PDB文件的顺序,这与MSDN中介绍的是一样的。

Symbol Settings窗口里,还可以从服务器上缓存符号文件,可是我试了很多方式,均没有成功。

为什么讲这个设置符号文件呢?因为有时候,有些项目非常庞大,并且代码是共享的,所以代码会放到服务器上。很多很大PDB调试文件,如果拷贝到本地电脑上比较麻烦。这个时候,就可以指定网络路径,直接通过网络路径调试。

静态库的PDB文件

静态库也有自已的PDB文件,只不过其名字是VC80.PDB/VC100.PDB这样的名字。静态库的PDB文件会在链接时合并到EXE/DLL的PDB文件中去。如果生成的静态库lib里有记录相应的PDB文件,却又没有相应的PDB文件,那么静态库链接成EXE/DLL时就会报警告找不到静态库对应的PDB文件。所以如果静态库作第三方库发布时,可以不用生成PDB文件,这样调用者链接时就不会报警告。

通过PDB文件可以获取函数名及对应的代码行号,更多信息可以参考微软给的示例。

更多详细资料见:https://msdn.microsoft.com/zh-cn/library/2008hf0e

相关文章:

  • typedef用法详解
  • c数据类型
  • C++常用数据类型和Windows常见数据类型
  • C 语言中 void* 详解及应用
  • 句柄是什么
  • #define用法
  • c语言预处理命令
  • C++头文件和std命名空间
  • C++输入输出(cin和cout)
  • C++运算符重载的概念和语法
  • GetLastError,ErrLookUp,$err,hr,$eax
  • 字符集和字符编码(Charset Encoding)
  • 进程
  • Windows中的对象
  • Windows对象、句柄与MFC对象
  • 【Linux系统编程】快速查找errno错误码信息
  • canvas 五子棋游戏
  • centos安装java运行环境jdk+tomcat
  • Docker 笔记(2):Dockerfile
  • express.js的介绍及使用
  • express如何解决request entity too large问题
  • hadoop入门学习教程--DKHadoop完整安装步骤
  • Java知识点总结(JavaIO-打印流)
  • nodejs:开发并发布一个nodejs包
  • Solarized Scheme
  • 编写高质量JavaScript代码之并发
  • 服务器之间,相同帐号,实现免密钥登录
  • 湖南卫视:中国白领因网络偷菜成当代最寂寞的人?
  • 每天一个设计模式之命令模式
  • 那些被忽略的 JavaScript 数组方法细节
  • 区块链技术特点之去中心化特性
  • 日剧·日综资源集合(建议收藏)
  • 一些css基础学习笔记
  • #周末课堂# 【Linux + JVM + Mysql高级性能优化班】(火热报名中~~~)
  • $forceUpdate()函数
  • (react踩过的坑)antd 如何同时获取一个select 的value和 label值
  • (Spark3.2.0)Spark SQL 初探: 使用大数据分析2000万KF数据
  • (分享)自己整理的一些简单awk实用语句
  • (九)c52学习之旅-定时器
  • (企业 / 公司项目)前端使用pingyin-pro将汉字转成拼音
  • (实战篇)如何缓存数据
  • (四)汇编语言——简单程序
  • (转)程序员技术练级攻略
  • (转)四层和七层负载均衡的区别
  • (转)用.Net的File控件上传文件的解决方案
  • (轉貼) 資訊相關科系畢業的學生,未來會是什麼樣子?(Misc)
  • (自适应手机端)响应式新闻博客知识类pbootcms网站模板 自媒体运营博客网站源码下载
  • .gitattributes 文件
  • .NET Core实战项目之CMS 第十二章 开发篇-Dapper封装CURD及仓储代码生成器实现
  • .Net 应用中使用dot trace进行性能诊断
  • .net程序集学习心得
  • .net图片验证码生成、点击刷新及验证输入是否正确
  • ::什么意思
  • [<死锁专题>]
  • [AHOI2009]中国象棋 DP,递推,组合数