gpt4 book ai didi

c# - "skipped loading symbols for ngen binary"用于 C# dll

转载 作者:可可西里 更新时间:2023-11-01 09:10:00 25 4
gpt4 key购买 nike

我正在尝试从 native C++ 可执行文件调试 C# dll。我有一个 C# COM 对象,它通过 IDispatch 从 native 代码加载和运行。一切都在调试中构建,包括 C# 和 C++ 代码。虽然我可以看到所有的 c++ 代码,并且所有的 c++ dll 都加载了它们的符号并可用于调试、断点等,但 C# 代码拒绝播放。

我看到的是 C# dll 都拒绝加载它们的符号 pdb,并在模块窗口中报告“skipped loading symbols for ngen binary”。

顺便说一句,我在这里调试 C# 解决方案,我在 COM 项目的调试设置中将 native 可执行文件设置为“启动外部程序”。

现在我可以启动 C++ 可执行文件,然后附加到它,然后一切都按我预期的那样工作 - 符号加载,我可以在 C# 中设置断点。

这是使用 Visual Studio 2013u4。是否有启用混合模式调试的设置?一个小问题是 native 代码是使用 VS2010 构建的。


Modules output when debugging external process

这是模块窗口 - 请注意所有 pdb 和 dll 都在一个目录中,您可以看到已加载的 c++ dll,但看不到 C# 的。

Modules output after attach to process

这是模块窗口 - 注意 EvCom dll(COM 对象)的第 3 个条目,我假设它是启用调试的条目。

Output 窗口中没有任何感兴趣的内容,当加载 COM dll 时,我看到以下内容(在附加到正在运行的进程的情况下,另一个只有 2 行而不是 3 行)。

'Explorer.exe' (Win32): Loaded 'C:\Dev\...\lib\debug\EvCom.dll'. 
'Explorer.exe' (Win32): Loaded 'C:\Dev\...\lib\debug\EvCom.dll'.
'Explorer.exe' (Win32): Unloaded 'C:\...\lib\debug\EvCom.dll'
'Explorer.exe' (Win32): Loaded 'C:\Dev\...\lib\debug\EvCom.dll'.

一件有趣的事——我检查了调试设置中的“使用托管兼容模式”,并认为它在开始调试时仍然没有加载我的符号,它只在模块列表中显示 1 个条目。这次为 C# dll 说“符号文件中没有 native 符号”。

看起来问题是无法在 VS2013(或 2012)中选择调试器类型。 This connect article建议其“按设计”和一些变通办法。

最佳答案

原来这一切都归功于 .NET 4.0 调试引擎的变化

.NET 4 及更高版本使用与 .net 3.5 及以下版本不同的调试引擎,当您开始调试 native 应用程序时,调试器将为您选择一个 .net 调试器(默认为 .net 4.0),如果您的 .net dll是使用这个平台构建的,一切都会好起来的——断点会被击中。

如果您加载的 dll 是 .net 3.5,那么调试引擎将无法理解加载的 dll,并且会拒绝加载符号或调试。

解决方案要么重建为 .net 4,要么启动 native 可执行文件并附加到它(您可以在其中选择调试器类型,“旧”.net 或"new".net),或者您可以创建一个从可执行文件中创建项目并设置其调试设置以指定正确的调试器。

我觉得恼人的是,Microsoft 可以很容易地使用您正在调试的项目中指定的 .NET Framework 类型启动调试器(毕竟,在调试 dll 并指定外部程序时,您仍然想调试dll 你按 F5 键,所以你知道要使用什么调试器!)(更烦人的是,一旦在加载的 dll 中启动托管调试,你就可以进入使用构建的项目较旧的 .net 框架没有问题)。

有关 this Microsoft connect 的更多详细信息文章

关于c# - "skipped loading symbols for ngen binary"用于 C# dll,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27169558/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com