1

我收到了十几个转储文件。使用 windbg/sosex 命令!dumpstack -EE,他们中的很多人最后都会显示这些行:

0aa6ce7c 028ea126 (MethodDesc 02756288 +0x16 TheCompany.Toolbox.Log.Logger.Info(System.String))
0aa6cecc 028ea126 (MethodDesc 02756288 +0x16 TheCompany.Toolbox.Log.Logger.Info(System.String))
0aa6cf54 028ea126 (MethodDesc 02756288 +0x16 TheCompany.Toolbox.Log.Logger.Info(System.String))
0aa6d080 6f42bc51 (MethodDesc 6f1da670 +0x81 System.TimeSpan.TimeToTicks(Int32, Int32, Int32))
0aa6d0a8 6f42c0a0 (MethodDesc 6f1daf1c +0x40 System.DateTime.TimeToTicks(Int32, Int32, Int32))
0aa6d0d0 6f42cb8f (MethodDesc 6f1da8ec +0x7f System.DateTime.Add(Double, Int32))

不幸的是,尝试获取局部变量!clrstack -a并没有给我合理的结果:

0:045> !clrstack -a
OS Thread Id: 0xf50 (45)
Child SP       IP Call Site
0aa6ed78 76df7094 [GCFrame: 0aa6ed78]
0aa6ef5c 76df7094 [DebuggerU2MCatchHandlerFrame: 0aa6ef5c]

有没有办法移动到最后一帧之外的另一帧?(以便在此框架中获取本地人)。

在本机模式下,我可以这样做:

.frame @$.frame +1

然后我可以在前一帧中有当地人

dv

我想知道如何对托管堆栈执行相同的操作,以便我可以!clrstack -a在以前的帧中执行此操作。我也想知道这个堆栈帧中的函数参数值/引用。

是否有执行此类操作的命令?

4

1 回答 1

3

史蒂夫约翰逊的SOSEX!mframe命令。

尽管您已标记问题,但您没有使用任何 SOSEX 命令,仅使用 SOS 命令,这可能是您未找到该命令的原因。

您从!mk. 如果您启用了 DML,则可以单击帧号并!mframe自动执行命令。之后,您可以!mdv显示参数和局部变量。

或者,!mdv <frame>也直接取帧号。

但是,我不确定这是否总是有帮助。SOSEX 不能变魔术,需要依赖 .NET 框架提供的信息。如果由于某种原因它被破坏了,你可能会很不走运。

于 2015-10-14T18:41:32.180 回答