windows关于程序release 加上调试信息 利用pdb dump定位的问题

来源:互联网 发布:淘宝店推广策划报告 编辑:程序博客网 时间:2024/06/03 19:36

本来release默认一般是删除所有的调试信息,然后编译时带有优化的参数,然后实现附带信息的减少,程序执行性能的提高。 但是可能你突然有想法需要在程序release版中加入信息,然后通过第三方库(crashrpt ,gppgle breakpad..)或者自己利用系统api去实现在用户使用的时候,能够在程序crash时,生成一个dump文件,然后上传给你,利用它来进行程序的调试,这样更方便找到问题。

当然不需要调试信息,你也可以通过其他的方法来获得错误的信息,代码的位置。但是这里讨论的是最方便的方法,就是拿到dump利用pdb然后用vs之类的进行调试马上就能定位到代码位置。

其实release debug差别的也就是一点点的选项,编译器的选项关于调试信息的贴一下官网的:

/Z7、/Zi、/ZI(调试信息格式):

不生成任何调试信息,因此编译较快。

/Z7

生成包含用于调试器的完整符号调试信息的 .obj 文件。 符号化调试信息包含变量的名称和类型以及函数和行号。不生成任何 .pdb 文件。

对于第三方库的分发服务器,不生成 .pdb 文件是一个优点。 但是,在链接阶段和调试期间,用于预编译头的 .obj 文件是必需的。如果 .pch 对象文件中只有类型信息(没有代码),则还必须使用 /Yl(为调试库插入 PCH 引用) 进行编译。

/Zi

生成一个程序数据库(PDB),其中包含供调试器使用的类型信息和符号化调试信息。 符号化调试信息包含变量的名称和类型以及函数和行号。

/Zi 不影响优化。 但是,/Zi 的确暗示了 /debug;有关更多信息,请参见 /DEBUG(生成调试信息)

类型信息放置在 .pdb 文件而不是 .obj 文件中。

可以将 /Gm(启用最小重新生成)/Zi 结合使用,但使用 /Z7 编译时不能使用/Gm

使用 /Zi/clr 编译时,DebuggableAttribute 特性将不会放置到程序集元数据中;如果要使用该特性,则必须在源代码中指定它。该特性可影响应用程序的运行时性能。 有关 Debuggable 特性如何影响性能以及如何减轻性能影响的更多信息,请参见令映像更易于调试

/ZI

采用支持“编辑并继续”功能的格式生成程序数据库(如上所述)。 如果想使用“编辑并继续”调试,则必须使用此选项。因为大多数优化与“编辑并继续”不兼容,所以使用 /ZI 会禁用代码中的所有#pragma optimize 语句。

/ZI 会导致在编译中使用 /Gy(启用函数级链接)/FC(所诊断源代码文件的完整路径)

/ZI/clr(公共语言运行时编译) 不兼容。

说明说明

/ZI 仅可在面向 x86 的编译器中使用;此编译器选项不能在面向 x64 或 ARM 处理器的编译器中使用。

编译器将程序数据库命名为 project.pdb。如果编译没有项目的文件,则编译器将创建名为 VCx0.pdb. 的数据库,其中x 是正在使用的 Visual C++ 的主版本。 编译器将 PDB 的名称嵌入每个使用此选项创建的 .obj 文件中,从而使调试器了解符号和行号信息的位置。 当使用此选项时,.obj 文件将较小,因为调试信息存储在 .pdb 文件中而不是 .obj 文件中。

如果从使用此选项编译的对象创建库,则在将库链接到程序时,关联 .pdb 文件必须可用。 因此,如果分发此库,就必须分发 PDB。

若要不使用 .pdb 文件创建包含调试信息的库,必须选择编译器的 C 7.0 兼容 (/Z7) 选项。如果使用预编译头选项,则预编译头和其他源代码的调试信息都放在 PDB 中。指定了“程序数据库”选项时将忽略 /Yd 选项。


然后就是链接器的选项了,链接器需要启用/DEBUG 还有 /PDB ,之前自己尝试,在编译选项里加上zi 之后,制定了pdb位置,然后如果同时存在优化选项o是无法定位到行的。然后重新是了一下在连接选项里 加入了/PDB , 这时候生成的pdb是和编译选项zi fd生成的不同的,这个却可以和优化选项同在,调试定位正常。后来查了一下。

http://msdn.microsoft.com/zh-cn/library/kwx19e36.aspx只有官方资料大概有提。 就是说到LINK时实际上是会把之前生成的pdb当成一个输入,然后更新后会有不同的pdb生成,但具体修改了什么,我还没弄清楚。不过暂时的问题是解决了的。其实也就这个有点小疑惑,其他的资料上都说的很清楚了。

0 0