DebugDiag没有显示.NET 4下的.NET堆栈信息

感觉就像这可能是一个简单的答案,但我一直无法找到它。

有问题的场景是C#.NET控制台应用程序。

我通常使用DebugDiag 1.2来检查来自我们经历的挂起的.dmp文件 – 通常是线程锁定问题。 它们是使用DebugDiag的“Create Full Userdump”选项创建的。

我最近开始编译面向.NET 4的应用程序,准备开始使用.NET 4的一些function。 但是,我注意到在使用DebugDiag分析这些.dmp文件时,缺少所有.NET堆栈信息。

如果我将CLR目标更改回.NET 3.5,并从新的可执行文件中捕获.dmp,那么.NET调用堆栈信息就在那里。

当我查看DebugDiag的输出时,我看到一条说明:

CLR信息

CLR版本= 4.0.30319.17929 CLR调试器扩展= C:\ Program Files \ DebugDiag \ Exts \ psscor4.dll

.NET线程摘要

无法请求ThreadStore

我认为“无法请求ThreadStore”是问题的关键,因为.NET 3.5 .DMP文件(使用psscor2.dll)报告“线程摘要”标题下的所有线程信息。

是.dmp缺少信息的问题,还是DebugDiag由于某种原因无法检索它?

最终,这个解决了自己。 我向微软发了一个问题,他们说DebugDiag 1.1不支持.NET 4+。 他们不久前发布了v1.2,它确实 – 再次像魅力一样:

http://www.microsoft.com/en-us/download/details.aspx?id=26798

假设您正在进行完全转储,这可能与它如何共同定位sos有关。 在3.5以下它将使用mscorlib共同定位,而在CLR 4下它将使用clr共同定位。 这将取决于谁编写debugdiag是CLR 4容忍。

我遇到了同样的问题,对我而言,它有助于从DebugDiag的子目录“exts”中删除psscor4.dll

在DebugDiag-Report中,我的CLR运行时现在显示为:

CLR Information CLR version = 4.0.30319.18052 CLR Debugger Extension = C:\Windows\Microsoft.NET\Framework\v4.0.30319\sos.dll 

PS:请注意使用正确版本的DebugDiag(32位与64位)。