一个C#桌面应用程序(在Visual Studio Express版上)工作了,但5秒钟后就不工作了。

我尝试了以下方法:

确保在所有程序集上设置了调试配置、调试标志和完整的调试信息。从我的整个计算机中删除所有bin和obj文件夹以及与项目相关的所有DLL文件。从头开始重新创建导致问题的项目。重新启动。

我在解决方案中有两个Windows窗体项目。其中一个加载调试信息,另一个不加载。它们都引用了我试图在项目文件中以完全相同的方式获取调试信息的程序集。有什么想法吗?


我想在这里补充一点,当我回来回顾这个问题时,主要是为了我自己,即在加载程序集之前不会加载符号,并且在需要时才会加载程序集。如果断点位于仅在主程序集中的一个函数中使用的库中,则在调用该函数之前,不会加载符号(并且它将显示断点未命中)。


当前回答

我尝试了上面提到的一切,但都没有奏效。[清洁解决方案,并检查PDB文件等]

即使发布相同的解决方案,也无法解决问题。

然后我回到了我通常要做的事情(愚弄这个顽固的Visual Studio)

我所做的只是在代码中进行了一次有意的更改,并发布了解决方案。然后我恢复了更改并再次发布。

Voila[PDB文件消除邪灵]。。这不是一个明智的解决方案,但这确实奏效了-|

其他回答

对于发生此错误的某些情况,另一种解决方案是:检查您的Build Action。

我在一个asp.net MVC3项目中遇到了这个问题;我的一个控制器由于某种未知原因将其Build Action设置为EntityDeploy,尽管它应该是Compile。

在我的案例中,在我的项目财产中选中了“优化代码”。这导致VS将我的程序集视为“不是我的代码”,反过来,它也没有为它加载符号。

解决方案是取消选中此项。

我的问题是aspx、aspx.vb和aspx.designer.vb文件导入错误(可能是一个接一个地导入到项目中)。

断点位于aspx.vb中,但无法访问,并显示此问题的警告。

解决方案是删除这三个文件并再次导入它们。现在我可以到达断点了。

通过在下拉菜单中选择调试,确保您处于调试状态,而不是发布状态,如下图所示。

然后,尝试通过在解决方案资源管理器窗口中的解决方案上单击鼠标右键并选择“清理解决方案”来清理项目。

然后通过在解决方案资源管理器窗口中的解决方案上单击鼠标右键并选择“重建解决方案”来重建解决方案

我们找到了问题的原因。此代码使用.aspx文件的Page指令中的“CodeBehind”属性,而不是“CodeFile”属性(ASP.NET 2.0及更高版本)。经过几天的绝望,一个简单的搜索和替换解决了问题。