de goes here } 程序员不能控制解构器何时将被执行因为这是由垃圾收集器决定的。垃圾收集器检查不在被应用程序使用的对象。它认为这些条件是符合清楚的并且收回它们的内存。解构器也在程序退出时被调用。当解构器执行时其背后所发生的那一幕是解构器隐式调用对象基类的Object.Finalize方法。因此上述解构器代码被隐含转化成: protected override void Finalize() { try { // Cleaning up . } finally { base.Finalize(); } } 现在,让我们看一个解构器怎样被调用的例子。我们有三个类A,B和C 。B派生自A,C派生自B。每个类有它们自己的构造器和解构。在类App的main函数中,我们创建C的对象。 using System; class A { public A() { Console.WriteLine("Creating A"); } ~A()页码:[1] [2] [3] [4] [5] [6] [7] 第2页、共7页 |