调试诊断
DebugDiag 2 已完全重写,现在是一组可执行文件(EXE 和 DLL)。它不再是一组脚本,您可以轻松地对其进行修改以包含您想要的附加信息。
DebugDiag 的输出与您在 WinDbg+SOS 的!dumpheap -stat
输出中看到的类似:
...
575a4518 11547 560508 System.Object[]
575d37b8 91 892344 System.Byte[]
575d2ee4 3488 927512 System.Int32[]
575d0d48 72920 6939284 System.String
Total 120639 objects
其他方法
SOS!do <address>
只给出没有孩子的大小,但是有 SOS !objsize <address>
,它似乎包括孩子(不能与 Visual Studio 2013 交叉检查,只有 2012):
0:008> !do 0b938584
Name: SomeClass
MethodTable: 08947c0c
EEClass: 08956c38
Size: 292(0x124) bytes
...
0:008> !objsize 0b938584
sizeof(0b938584) = 11728 ( 0x2dd0) bytes (SomeClass)
要对堆上的所有对象执行此操作,您可以!objsize
在循环中为每个对象执行:
.foreach (address {!dumpheap -short}) {!objsize ${address}}
我知道递归列出属性值的唯一命令是 SOSEX's !mdt <address> -r
,但它不会输出大小。
仅使用 Pykd 分析根对象
Pykd脚本的起点:
0:000> .loadby sos clr; .loadby sos mscorwks
0:000> .load <full path>\sosex.dll
0:000> .load <full path>\pykd.pyd
0:000> !pycmd
>>> gch = dbgCommand("!gch")
>>> lines = gch.split('\n')
>>> for line in lines: dprint(dbgCommand("!objsize "+line[34:50]))
...
出现后按回车...
。请注意,[34:50]
这可能需要成为 32 位的适配器。