析构函数用于析构类的实例。
1.不能在结构中定义析构函数。 只能对类使用析构函数。
2.一个类只能有一个析构函数。
3.无法继承或重载析构函数。
4.无法调用析构函数。 它们是被自动调用的。
5.析构函数既没有修饰符,也没有参数。
如类 Car 的析构函数的声明:- class Car
- {
- ~Car() // destructor
- {
- // cleanup statements...
- }
- }
复制代码 该析构函数隐式地对对象的基类调用 Finalize。 这样,前面的析构函数代码被隐式地转换为以下代码:- protected override void Finalize()
- {
- try
- {
- // Cleanup statements...
- }
- finally
- {
- base.Finalize();
- }
- }
复制代码 这意味着对继承链中的所有实例递归地调用 Finalize 方法(从派生程度最大的到派生程度最小的)。
程序员无法控制何时调用析构函数,因为这是由垃圾回收器决定的。 垃圾回收器检查是否存在应用程序不再使用的对象。 如果垃圾回收器认为某个对象符合析构,则调用析构函数(如果有)并回收用来存储此对象的内存。 程序退出时也会调用析构函数。
可以通过调用 Collect 强制进行垃圾回收,但大多数情况下应避免这样做,因为这样会导致性能问题。
总结:
多数情况下c#中用不到析构函数,但如果在class中启用了非托管性资源,那么建议在其析构函数中进行适当资源清理工作(此时结合Dispose模式会更好),这会使.Net的自动垃圾回收和手动处理协调配合起来。
凡具有析构函数的class,其被识别为垃圾后,垃圾回收机制不会简单的进行回收处理,而是会将其加入到终结队列,再由第三方线程(因与主线程不存在数据冲突,故彼此可异步执行,不至应垃圾回收线程误了主程序的事)执行。编写析构函数要注意重点在清理非托管性资源,且不可将垃圾复活。
网上论坛有很多详细介绍,可以多去看看{:soso_e100:} |
|