您的位置:首页 > 其它

《Advanced .NET Debugging》 读书笔记 Listing 5-2: GC代龄的示例

2010-12-31 00:53 495 查看
代码如下:

using System;
using System.Text;
using System.Runtime.Remoting;

namespace Advanced.NET.Debugging.Chapter5
{
    class Name
    {
        private string first;
        private string last;

        public string First { get { return first; } }
        public string Last { get { return last; } }

        public Name(string f, string l)
        {
            first = f; last = l;
        }
    }

    class Gen
    {
        static void Main(string[] args)
        {
            Name n1 = new Name("Mario", "Hewardt");
            Name n2 = new Name("Gemma", "Hewardt");

            Console.WriteLine("Allocated objects");

            Console.WriteLine("Press any key to invoke GC");
            Console.ReadKey();

            n1 = null;
            GC.Collect();

            Console.WriteLine("Press any key to invoke GC");
            Console.ReadKey();

            GC.Collect();
           
            Console.WriteLine("Press any key to exit");
            Console.ReadKey();
        }
    }
}

1. 在WinDbg里载入05Gen.exe

2. 执行到需要按键继续处, 先执行 .loadby sos.dll mscorwks

3. 再执行 .load sosex.dll

4. 执行 !eeheap –gc 可看到各代龄对象的统计状况。执行!clrstack –a 可以看到对象指向的heap地址:





此时可以发现,local指向的heap对象地址0x00000000024b3900 比generation 0的地址 0x0000000002401030还要大,可见其处于带龄0.

5. 当执行一次GC之后,再次重复以上过程,可得:





可见该对象已经指向的heap地址0x000000002424358已经位于代龄0的地址0x0000000002425630和代龄2的地址0x0000000002401018之间,可见该对象在经过一次gc之后,已经成了代龄为1的对象。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐