3

Visual Studio 2013 可以显示包含大小的列(包括子对象的大小) - http://blogs.msdn.com/b/visualstudioalm/archive/2013/10/16/net-memory-analysis-enhancements-in -visual-studio-2013.aspx

DebugDiag 的内存分析报告目前只显示对象大小,不包括子对象。有没有办法让 DebugDiag 在其报告中包含子对象的大小?

你的建议是为 .NET 4.0 生成此类报告的好方法,因为 Visual Studio 仅支持分析 .NET 4.5 故障转储

包含大小

4

1 回答 1

4

调试诊断

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 位的适配器。

于 2014-09-18T14:09:37.237 回答