【问题标题】:Advanced .NET Debugging高级 .NET 调试
【发布时间】:2013-02-13 17:43:41
【问题描述】:

我正在阅读 Advanced .NET Debugging 这本书,我非常喜欢它。但是我对这些例子有一些问题。如果有人读过它帮助我,我将不胜感激。

我有两个问题:

  1. 与构建示例的 .NET 框架的哪个版本相比?我无法在 windbg(x86) 下运行它们并且它们在 windbg(x64) 下加载,所以我假设它是 64 位版本的框架。但是哪个框架? 2.0、3、3.5、4?

  2. 查看第 2 章中描述的类型句柄(方法表)时,我得到了不同的结果(我的结果和书中显示的内容如下所示)。当然,我不是在谈论地址不同。例如,当我在方法表上 dd 时,我看到 Flags2 字段、NumMethods 字段的不同值。我不知道为什么。在第 56 页作者说对象的大小是 0x14(在我的机器上相同),因为对象有 4 个整数。但是 02TypeSample.cs 的列表只显示了 3 个整数,x、y、z。在我的机器上,dd 显示 4 个方法,而在示例中显示 7 个。Book 还说编译器生成了默认 ctor。

    “首先要记住的是,即使我们做到了 没有显式定义任何构造函数,C#编译器会自动生成一个 我们的默认构造函数。

    在列出时,您可以看到 TypeSample 的 ctor 将 3 个整数作为参数。要么是我出了问题,要么是书,要么是例子。它是什么? ;)

Method table from the book:
0:000>dd 002930b0
002930b0 00040000 00000014 00070402 00000004
002930c0 790fd0f0 00292c3c 002930f8 00291244
002930d0 00000000 00000000 79371278 7936b3b0
002930e0 7936b3d0 793624d0 003400c8 0029c015
002930f0 0034007000000000 00000080 00000000
00293100 00000000 00000000 00000000 00000000
00293110 00000000 00000000 00000000 00000000
00293120 00000000 00000000 00000000 00000000

My method table:
0:000> dd 00223420 
00223420  00000000 00000014 00040011 00000004
00223430  68b70944 00222fe4 00223458 00221390
00223440  00000000 00000000 68ac6a90 68ac6ab0
00223450  68ac6b20 68b37700 00000080 00000000
00223460  00000000 00000000 00000000 00000000
00223470  00000000 00000000 00000000 00000000
00223480  00000000 00000000 00000000 00000000
00223490  00000000 00000000 00000000 00000000

it shows 4 methods when !dumpmt shows 7

0:000> !dumpmt -md 00223420 
EEClass: 00221390
Module: 00222fe4
Name: Advanced.NET.Debugging.Chapter2.TypeSample
mdToken: 02000002  (F:\Development\Advanced .NET Debugging\adndsrc\Chapter2\TypeSample\TypeSample\bin\Debug\TypeSample.exe)
BaseSize: 0x14
ComponentSize: 0x0
Number of IFaces in IFaceMap: 0
Slots in VTable: 7
--------------------------------------
MethodDesc Table
   Entry MethodDesc      JIT Name
68ac6a90   6894494c   PreJIT System.Object.ToString()
68ac6ab0   68944954   PreJIT System.Object.Equals(System.Object)
68ac6b20   68944984   PreJIT System.Object.GetHashCode()
68b37700   689449a8   PreJIT System.Object.Finalize()
003d00d8   00223398      JIT Advanced.NET.Debugging.Chapter2.TypeSample..ctor(Int32, Int32, Int32)
0022c015   002233a4     NONE Advanced.NET.Debugging.Chapter2.TypeSample.AddCoordinates()
003d0070   002233b0      JIT Advanced.NET.Debugging.Chapter2.TypeSample.Main(System.String[])

【问题讨论】:

    标签: debugging windbg sos memory-dump


    【解决方案1】:

    书的背面说它针对 .NET CLR 4.0。但是,前言的示例代码部分指出所有代码都是使用 C# 和 .NET 2.0 编写的。最后有一章是关于 .NET 4.0 的。

    上面!dumpmt 命令的输出显然是32 位(x86),因为Entry 列是一个指针。

    关于你的第二个问题。您能否指定您所指的示例。

    【讨论】:

    • 为了获得类似于书中内容的输出,我下载了源代码并针对 x86 构建了它们。来自书籍网站的二进制文件无法在 windbg x86 下运行。它们在 windbg x64 中工作,但所有地址都是 64 位的,看起来一点也不像书中的那样。在我的第二个问题中,我从第 43 页的清单 2-5 和从第 53 页开始的类型句柄部分。
    • 也在我看到的所有示例中:.loadby sos.dll mscorwks。所以它不能针对 CLR 4.0。我认为 mscorwks 在 CLR 4.0 中被重命名为 clr。
    • 感谢您的更新。我会看看这本书,看看我是否能理解它。我没有查看消息来源,因此无法对此发表评论。但是,我在书出版时写了作者,他非常友好地回答了我的问题。您可能想尝试一下。您是正确的,DLL 在 4.0 中已重命名为 clr.dllmscorwks.dll 是 2.0 的 dll。这与示例代码部分中的信息非常吻合。
    • 我在这里提问之前尝试联系作者。但是很遗憾,图书网页上的联系表格不起作用。
    • 请给我发邮件(我的电子邮件在我的个人资料中列出),我会让您与作者联系。谢谢。
    【解决方案2】:

    要构建 X86 程序集,您可以修改构建 XML。提供的 XML 似乎在 64 位窗口上将程序集构建为 X64。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2011-03-25
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多