码迷,mamicode.com
首页 > 其他好文 > 详细

VS2012中使用SOS调试CLR

时间:2017-08-02 11:56:34      阅读:292      评论:0      收藏:0      [点我收藏+]

标签:microsoft   选中   进制   托管   img   arch   font   括号   打开   

之前看了《用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底层的世界其乐无穷,期待有心人去探索

 

来源于

http://www.cnblogs.com/marsblog/p/3275650.html

VS2012中使用SOS调试CLR

标签:microsoft   选中   进制   托管   img   arch   font   括号   打开   

原文地址:http://www.cnblogs.com/yxhblog/p/7272975.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!