代码改变世界

VS2012中使用SOS调试CLR

2013-08-22 18:40  黑眼圈Mars  阅读(1363)  评论(1编辑  收藏  举报

之前看了《用WinDbg探索CLR世界》的一些列文章,发现SOS真的是一个非常好的调试.net的工具,

然后又惊喜的在http://blogs.msdn.com/b/mariohewardt/archive/2012/06/05/visual-studio-2012-and-windbg-integration.aspx 上看到原来windbg已经被集成

到VS2012的IDE中。本文主要讲解在VS2012中调用SOS的基本步骤

1 SOS是一个非托管的DLL,要使用SOS调试,首先需要打开本地的非托管代码调试选项,

Debug--->Options and Settings --->Suppress JIT optimization on module load(Managed only),将其取消

 

 

然后需要打开项目的本地调试选项

project--->yourproname properties --->Debug--->Enable native code debugging

 

2 按步骤一设置好以后,就可以开始我们的SOS之旅了。

首先我们需要定位到运行的某个时刻,F9在某条语句上设置断点,F5运行至Console.Read(),

然后我们打开immediate窗口,Debug--->Window--->Immediate

输入.load SOS

输入成功以后 会显示

输入! help可以查看SOS的使用帮助,如果出现PDB symbol for clr.dll not loaded,可以通过选中

Tools ---> Option--- > Debugging ----> Symbols-->Microsoft Symbol Servers’ checkbox来解决

 

3 如果我们要查看某个对象的信息,可以输入!dumpstackobjects,查看所有在CLR中已经生成的对象信息,

接下来我们看下object o的具体信息

输入!dumpobj(019f240f),没错,括号中的参数就是dumpstackobjects命令所显示的16进制数

 

由此可以看到,一个空的对象在GC堆中占用的内存是12个bytes,在<CLR VIR C#>中提到,其中有8个bytes是对象类型指针和同步索引快,剩下4个bytes为空

很有意思的是,如果我们定义一个对象,只含有一个int型的私有字段,那么它所占用的内存也是12个bytes

本文就到这里,CLR底层的世界其乐无穷,期待有心人去探索

作者:Mars

出处:http://www.cnblogs.com/marsblog/

本文基于署名-非商业性使用 3.0中国大陆许可协议发布,欢迎转载,演绎或用于商业目的,但是必须保留本文的署名 Mars (包含链接)