当前位置:主页   - 电脑 - 程序设计 - C#
CLR探索系列:Windbg+SOS动态调试分析托管代码
来源:网络   作者:   更新时间:2012-02-26
收藏此页】    【字号    】    【打印】    【关闭

  在使用VS进行托管应用程序的调试的时候,有的时候总感觉有些力不从心。譬如查看一个托管堆或者计算堆栈的时候,VS就不能胜任了。这个时候,Windbg+SOS扩展调试模块就为我们提供了一个很好的解决方案。

  我们看一段代码:

class Program
  {
    static void Main(string[] args)
    {
      Program b = new Program();
      b.test();
      System.Console.ReadLine();
    }
    public void test()
    {
      int i = 67;
      System.Console.WriteLine((char)i);
      System.Console.WriteLine((char)67);
      i = 1;
    }
  }

  这是C#里面的一个强制类型转换,我们现在用windbg+SOS来分析下计算堆栈,以及强制类型转换之后的JIT代码。

  在windbg里面加载这个正在运行的程序,attach to this process,然后加载SOS扩展调试模块:

  0:003> .load C:WINDOWSMicrosoft.NETFrameworkv2.0.50727SOS.dll

  然后显示当前的线程:

0:003> ~
  0 Id: cf0.450 Suspend: 1 Teb: 7ffdf000 Unfrozen
  1 Id: cf0.be8 Suspend: 1 Teb: 7ffdd000 Unfrozen
  2 Id: cf0.168 Suspend: 1 Teb: 7ffdc000 Unfrozen
. 3 Id: cf0.7d0 Suspend: 1 Teb: 7ffde000 Unfrozen

  切换到第0个线程:

0:003> ~0s
eax=0012f2e4 ebx=00000000 ecx=0012f400 edx=00000008 esi=0012f1f4 edi=00250688
eip=7c92eb94 esp=0012f194 ebp=0012f1b4 iopl=0     nv up ei pl zr na pe nc
cs=001b ss=0023 ds=0023 es=0023 fs=003b gs=0000       efl=00000246
ntdll!KiFastSystemCallRet:
7c92eb94 c3       ret

其它资源
来源声明

版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明