本文主要记录一些我们在debug 托管代码dumpfile的时候常用命令。
1. lm 命令
在windbg打开dumpfile之后,我们可以利用lm命令去列出当前加载的dll,如果想详细查看某个dll的信息,比如aaa.dll,那么可以利用命令lmv maaa去显示aaa的详细信息,包括版本信息等等。
2. k(b)命令
可以利用该命令列出当前线程的callstack,想列出所有线程的call stack信息,可以~*k,或者~*kb
3. 利用SOS.dll的扩展命令
3.1 !clrstack 列出当前线程的托管程序的call stack信息,如果包含参数 -p(!clrstack -p),则列出的信息包含函数参数,如果-a(!clrstack -a),则列出的信息包含函数参数以及局部变量的信息。
3.2 !dumpdomain,如果没有参数则列出所有AppDomains中的dll信息,当然可以指定domain的地址,从而显示某个domain中dll的信息。
3.3 !dumpstackobjects(!dso),可以列出当前stack中的所有manged对象,通过该命令可以查出是否有exception 对象或者想找的对象,然后再去利用得到的地址去查看该对象的所有属性,
3.4 !dumpobj,可以列出manged对象的Field,从而帮助开发人员判断问题。
3.5 !dumpheap,用来查看垃圾回收堆里面的统计信息。
当然如果要查具体命令的解释,可以用!help +命令,比如!help dumpobj,可以查看dumpobj的解释。!开始的为扩展命令,如果要查看元命令则领用.help + 元命令的格式,比如.help attach ,可以查看attach的解释。