VS2012中使用SOS调试CLR

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

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

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

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

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

 

 

而后须要打开项目的本地调试选项3d

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

 

2 按步骤一设置好之后,就能够开始咱们的SOS之旅了。调试

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

而后咱们打开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 (包含连接)

相关文章
相关标签/搜索