我收到了十几个转储文件。使用 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
在以前的帧中执行此操作。我也想知道这个堆栈帧中的函数参数值/引用。
是否有执行此类操作的命令?