VS调试时断点无法进入或命中的原因及解决方法(PDB引发的)

在使用VS开发时,有时断点会无法进入,特别是在一个项目中引用另一个类库项目时。如下图。


我在一个项目中引用了自定义的控件MyControl类库,但在使用时发现,有些地方还需要调整,比如这里我需要增加一个GUID作为特殊标识,并输出以供测试。但是当我将这段代码加入进去后,按F5运行程序时,这段代码的断点没有如预期的进入。

注:无法进入的断点是空心的,可以进入的断点是实心的。

于是将鼠标定位到了断点的位置,提示如上图。会发现这是因为源代码与原始版本不同造成的。这时我们可以按照提示中所说的方法来解决试试。

解决方法1:右击断点->位置->允许源代码与原始版本不同。如下图

(注意要在非运行状态下右击断点,不然会无法更新代码)


但是在实际运行时会发现,此方法并不一定靠谱,因为调试时断点自动往下跳了。这样一来,断点同样会无法进入。

解决方法2:工具->选项->调试->常规->禁用要求源文件与原始版本完全匹配如下图


这时再运行,断点已经可以正常进入了。

解决方法3:重新生成解决方案或者先清理解决方案再生成解决方案


这时再运行,断点也可以正常进入。

那么为什么会造成这种情况呢?这时因为调试时使用的是PDB(Program Database)文件,而当我们在类库中修改代码后,由于没有重新编译,会使用上次的PDB文件,这样就造成了原来的PDB和新的代码文件不匹配,自然调试时也就无法正确进入断点。

再有前面提到,有时断点会跳到其他的位置,是因为断点是定位在代码的行上的,而PDB文件中记录了代码的行数,但是PDB文件却没有更新,所以当我们强行将断点处的代码设置"允许源代码与原始版本不同"时,如果依旧使用上一次的PDB文件,自然断点的行数就定位到了上次记录的代码行数,所以断点就会往后跳了。

关于PDB的说明可以参看该文http://www.codeproject.com/Articles/349076/Know-Program-Database-file-PDB




  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在C#远程调试,如果当前不会命中断点并且出现了"还没有为该文档加载任何符号"的错误提示,通常是因为调试无法加载符号文件。 解决这个问题的方法有以下几种: 1. 确保符号文件与调试的程序文件匹配:符号文件(.pdb文件)包含了程序的调试信息,确保你使用的符号文件与正在调试的程序文件是匹配的。如果符号文件与程序文件不匹配,调试器将无法正确加载符号信息,导致无法命中断点。 2. 配置远程调试环境:确保你的远程调试环境已正确配置。远程调试需要在远程计算机上启动调试器,同在本地计算机上连接到远程调试会话。确保远程计算机和本地计算机的调试器版本匹配,并遵循正确的远程调试配置步骤。 3. 设置调试器加载符号文件的路径:在 Visual Studio 中,你可以通过打开“调试”菜单,选择“选项”->“调试”->“符号”来配置调试器加载符号文件的路径。确保符号文件所在的路径被包含在调试器的符号文件搜索路径中。 4. 清理和重新生成解决方案:在 Visual Studio 中,可以尝试清理解决方案并重新生成它。有,编译器可能没有正确生成符号文件或者符号文件可能已过期,重新生成解决方案可能解决这个问题。 如果上述方法都无效,可能需要进一步检查调试器和符号文件的配置,确保调试器和符号文件的版本匹配,并且符号文件没有损坏。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值