整理一些平时调试.NET Application使用WinDbg + SOS的常用命令

1、加载调试扩展sos.dll,对应路径由CLR版本决定(比如:v2.0.50727、v4.0.30319)

.load C:\Windows\Microsoft.NET\Framework64\v4.0.30319\sos.dll

2、显示当前托管堆栈,显示非托管用kb

!clrstack
!clrstack -a
kb

3、显示托管线程

!threads
!threads -live

4、显示所有线程下托管调用堆栈

~* e !clrstack

5、设置断点

!bpmd ConsoleApplication1.exe ConsoleApplication1.Program.Main

6、查看当前托管调用堆栈对象实例列表

!dumpstackobjects

7、线程切换,用!threads查看线程列表,使用TheadId切换,默认WinDbg为调试线程

~0 s

8、显示已加载模块版本列表

lmv

9、显示Module、Assembly、MethodTable、EEClass相关信息

!name2ee ConsoleApplication1.exe ConsoleApplication1.Program

10、显示EEClass的具体定义(包括mdToken、Method Table),通过!name2ee获取对应的EEClass值

!dumpclass 000007fe96e1d9b0

11、显示具体某个类型实例

!do 00000003ffe933d0

12、显示线程的cpu使用时间(用户模式、内核模式)

!runaway

13、显示托管堆对象统计,!dumpheap有多个参数对返回结果进行筛选

!dumpheap -min 50
!dumpheap -type System.Data.DataTable

14、显示数组

!da 0000000140b83258
!da -start 0 -length 30 -details 0000000140b83258

 15、停留在指定类型异常

!StopOnException System.IO.FileNotFoundException

 

SOS.dll => http://msdn.microsoft.com/en-us/library/bb190764.aspx

Common WinDbg Commands => http://www.windbg.info/doc/1-common-cmds.html

posted @ 2012-11-12 22:51  junchu25  阅读(542)  评论(0编辑  收藏  举报