调试DLL的发行版本(带PDB文件)

如果我有一个DLL(以发布模式构建)和相应的PDB文件,是否可以调试(步入)该DLL中包含的类/方法?

如果是,那么所需的步骤/配置是什么(例如,放置PDB文件的位置)?

编辑:

如果将PDB文件与DLL放在同一位置(在简单控制台测试应用程序的bin / debug目录中)。 我可以看到DLL的符号被加载(在“输出”窗口中,也在“模块”窗口中),但我仍然无法进入该DLL的方法。

这可能是编译器优化的结果(正如Michael在他的回答中所描述的那样)?

如果pdb位于dll旁边(就像使用intellisense xml文件一样),通常会检测到pdb(至少对我而言)。

另外; 模块加载后你需要一个断点……

在断点处,调出“模块”窗口(Ctrl + D,M – 或调试 – > Windows->模块)。 右键单击你的dll“加载符号”,“符号路径”等。

是的,您可以使用PDB调试发布代码。 然而,调试优化代码存在一些缺陷, 这里和这里有更多信息。

您的PDB只需要在调试器可以找到它的位置 – 对于本地调试相同的目录,因为dll通常是最简单的。 否则,将它放在调试器可以找到它的某个位置,并使用符号路径将调试器指向该位置。

我终于找到了调试在发布配置中构建的DLL的问题:

首先,它基本上按预期工作。 这意味着,如果我有一个内置于发布配置的DLL加上相应的PDB文件,那么我可以调试该DLL中包含的类/方法。

当我第一次尝试这个时,我不幸地试图进入具有DebuggerStepThroughAttribute的类的方法,例如:

[System.Diagnostics.DebuggerStepThrough] public class MyClass { public void Test() { ... } } 

在这种情况下,当然不可能从调试器进入该方法(如预期/预期的那样)。

所以一切都按预期工作。 非常感谢你的回答。

调试发布版本通常比调试调试版本困难得多。 一般来说,您需要对x86汇编程序有所了解,并且您可能会花一些时间查看反汇编窗口。 这往往是确定您真正使用的代码行的唯一方法,因为在发布版本中,编译器上的优化可能会进行重要的内联和指令重新排序。 另外,我发现调试器经常无法正确报告变量值。 如果您需要知道变量的值并且您不确定调试器是否正确,请进入反汇编窗口并找到它所在的内存位置或寄存器。

pdb文件可以存储在Symbol Server中。 查看设置符号服务器以获得一个好的教程。 我们在构建机器上构建的每个产品都将符号发布到符号服务器,因此我们始终可以调试从WinQual收到的任何故障转储。