今天编写了一个Dll程序,并使用一个exe程序进行调用。但是代码调试时,却一直无法进入Dll程序代码。后面分析是因为我取消加载微软的PDB文件后,导致编译器也不会去加载自己编写的PDB文件导致的。
编译器: vs2013
系统:win7系统
编译配置: release 编译
下面记录问题解决过程:
当出现无法进行程序调试时,首先确认程序是否有优化、PDB文件是否有生成、以及是否因为源码和PDB文件不一致导致的。
1.程序没有优化
2.有生成调试文件
3.PDB文件和源文件可以不一致
在正常情况下,以上三个配置项均配置正确,是可以进行代码调试的。但是今天就是不可以,可以确定的是问题原因一定是PDB文件没有加载导致的。
突然意识到我进行代码调试的时候,vs总是会弹如下框:
因为加载很慢,我总是点击取消,在模块窗口中发现如下信息:
原来是编译器在我点击取消后,就禁用了utility.dll的符号文件加载,为了验证是否因为这个导致的,将编译器设置为不从microsof符号服务器加载PDB文件。
设置路径:工具->选项->调试->符号
重新编译并进行调试,代码已经可以进行入Dll程序,并成功断点。
问题解决。
总结
原来vs2013默认配置中,会从microsoft符号服务器下载PDB文件,导致程序调试总是很慢,点击取消后,就会导致编译器不会加载exe依赖的dll对应的PDB文件。
而vs2008默认配置中就不会下载库的PDB文件,从而vs2008调试时没有这个问题。