我正在努力克服这个障碍,我非常希望SO上的某个人可以提供帮助。
当我在类库项目中设置断点时。它看起来像一个正常的断点。当我开始调试我的解决方案时,breakpoint becomes hollowed out and has a yellow triangle with an exclamation point在里面。当我平移断点时显示的工具提示是“断点当前不会被命中。此文档没有加载符号。”
这个项目不是ASP.NET应用程序,它只是一个winForms应用程序。
我已经接管了解决方案中包含多个项目的现有winForms应用程序。我已经在调试模式下构建并运行了项目。我可以在某些项目的断点处停下来,但是,我无法在其他项目中找到断点,特别是我的项目类型为类库。
到目前为止我做了什么:
此外,我已按照SO帖子中列出的问题排查步骤进行操作:
the breakpoint will not currently be hit no symbols loaded
The breakpoint will not currently be hit. No symbols have been loaded for this document.
Fixing “The breakpoint will not currently be hit. No symbols have been loaded for this document.”
此外,我已阅读Google MSDN和Visual Studio 2008 "The breakpoint will not be currently hit. No symbols have been loaded for this document"以及其他地方的大量帖子,但这些帖子都不符合我的具体需求。
其中一些帖子是:
The breakpoint will not currently be hit. No symbols have been loaded for this document
Breakpoint will not currently be hit. No symbols loaded for this document.
The Breakpoint will not currently be hit. No Symbols have been loaded for this document.
{{3}}
我读过的所有帖子都非常丰富,但没有一个建议的解决方案符合我的特定需求。如果有必要提供更多信息,请与我们联系。我有更多的链接,我可以提供作为没有工作的参考。以及我尝试解决此问题的其他步骤。
我发布这个后续行动让每个人都感到惊讶。我按照@Hans @ suggestion来调用有问题的项目文件。
我放置了一个昏暗的frm作为form = new ProjectInQuestion.FormInQuestion
和
现在调试中的程序集加载 - > Windows的>模块
新问题比我原来的问题更令人困惑。我的断点看起来很好,但是被忽略了。断点处没有明显的错误。
答案 0 :(得分:12)
这可能是一个老问题,但我想在找到这个问题的解决方案之后回答这个问题,因为这是关于这个主题的最完整的问题之一。
<强>简介强>
我的项目是一个ASP.NET应用程序,但基本问题也会在WinForms上发生。当程序集输出中缺少DLL时,会出现问题。但是,如果您引用的DLL然后引用另一个不在程序集中的DLL,则会发生同样的异常。由于操作系统加载DLL的方式,引用的DLL必须位于环境路径中,而不是输出程序集中。
项目A引用DLL D. DLL D引用DLL X. DLL D可能在您的输出程序集中。 DLL X必须位于您的环境路径中。
此问题的核心原因在于操作系统在&gt;运行时加载本机DLL的方式。使用以下逻辑加载本机DLL,该逻辑不包括&gt;临时ASP.net文件和applications / bin文件夹。如果Native DLL不包含在带有.EXE&gt;文件的/ bin文件夹中,或者DLL不在路径环境变量中,则在&gt;任何.Net应用程序中也会出现此问题。
个人解决方案
我使用的是名为DivaAPIWrapper.dll的DLL(C#的托管DLL)。但是,我知道DivaAPIWrapper.dll需要DivaAPI.dll(非托管C ++)才能运行。我在所有输出路径中放置了DivaAPI.dll,但我一直收到此错误。只有在我将DivaAPI.dll放入我的环境路径(C:\ windows \ Microsoft.Net \ Framework \ v2.0.50727)后才能正常工作。 请注意:如果您使用的是较新版本的.NET框架,那么您的路径可能会有所不同!
Jerry Orman的完整解决方案
请参见链接:http://blogs.msdn.com/b/jorman/archive/2007/08/31/loading-c-assemblies-in-asp-net.aspx
答案 1 :(得分:7)
我也面临同样的问题,并从互联网上找到了许多解决方案,但解决方案对我有用,如下所示:
由于我在框架版本4.0中的应用程序,我试图将程序附加到v2.0以下的版本,因此请确保您的框架版本具有托管代码版本,如下所示。
答案 2 :(得分:4)
最近在附加到正在运行的进程时发生了这种情况。问题是调试选项设置为
附加到:原生代码
对于我的情况,它需要是:
附加到:托管代码
答案 3 :(得分:3)
我最近发现了一件事,工作得很好!!!
托管应用程序(正在调用您的dll的应用程序)必须具有以下行:
<supportedRuntime version="v4.0"/>
在&#34; WhateverApplicationItIs.exe.config&#34;文件,在<configuration>
部分内。
示例:(参见&#34; ...&#34;无论文件内部有什么内容并保持原样)
<configuration>
...
<supportedRuntime version="v2.0.50727"/>
</configuration">
PS:尝试将此版本与项目属性中设置的目标框架相匹配。我相信2.0.50727是3.5 Framework的一个很好的尝试,4.0 for 4.0 Framework。
对我来说,它刚刚解决了我试图在不同应用程序中调试的两个不同的DLL。
答案 4 :(得分:1)
我总是这样发生,就像你说断点在加载DLL之前一直没有活动。它确实没关系,因为它必须在代码到达那个点之前加载DLL。我的断点从这个开始,但它们总是被击中。
答案 5 :(得分:1)
检查您是否未更改要编译此项目的处理器。我有,当我改回来时,一切都恢复了。显然,处理器的变化使它“与原始的不同”
答案 6 :(得分:1)
我在Vb.net表单应用程序中遇到了与VS2008相同的问题,我在另一个项目中调用了一个dll,加载到同一个项目组中。我找到了这个简单的解决方案:我在form_load事件中加载了一个实例 Dim pmg As New PMGExport.PMGExportNeu。
答案 7 :(得分:1)
请检查工具栏上的“解决方案配置器”模式(“运行”按钮旁边)是否设置为“调试”而不是“释放”
答案 8 :(得分:1)
希望这会有所帮助......
我正在引用我的bin \ Release文件夹中的DLL,即使我处于调试模式。
我将DLL复制到bin \ Debug文件夹,当我运行VS时,断点被击中。
答案 9 :(得分:1)
试试这个, 在Vs 2008中,转到工具 - &gt;选项 - &gt;调试 - &gt;一般 - &gt; unchecked / disable&#39;要求源文件与原始版本完全匹配
答案 10 :(得分:1)
我在vs2010上遇到了同样的问题,我在流程步骤中解决了这个问题:
program Database(/ZI)
答案 11 :(得分:0)
请检查工具栏上的“解决方案配置器”模式(“运行”按钮旁边)是否设置为&#34; Debug&#34;而不是&#34;发布&#34; 为我工作
答案 12 :(得分:0)
在开始调试之前,请确保在Visual Studio中选择 debug mode
。
检查Visual Studio中 Play 按钮附近的下拉列表。