17.12 Destructors

本文详细介绍了析构函数的概念及其在类实例销毁过程中的作用。解释了如何声明析构函数,并探讨了其与类继承的关系。此外,还讨论了析构函数与垃圾回收之间的交互。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

A destructor is a member that implements the actions required to destruct an
instance of a class. A destructor is
declared using a destructor-declaration:
destructor-declaration:
attributesopt externopt ~ identifier ( ) destructor-body
destructor-body:
block
;
A destructor-declaration may include a set of attributes (§24).
The identifier of a destructor-declarator must name the class in which the
destructor is declared. If any other
name is specified, a compile-time error occurs.
When a destructor declaration includes an extern modifier, the destructor
is said to be an external destructor.
Because an external destructor declaration provides no actual
implementation, its destructor-body consists of a
semicolon. For all other destructors, the destructor-body consists of a
block, which specifies the statements to
execute in order to destruct an instance of the class. A destructor-body
corresponds exactly to the method-body of
an instance method with a void return type (§17.5.8).
Destructors are not inherited. Thus, a class has no destructors other than
the one which may be declared in that
class.
[Note: Since a destructor is required to have no parameters, it cannot be
overloaded, so a class can have, at most,
one destructor. end note]
Destructors are invoked automatically, and cannot be invoked explicitly. An
instance becomes eligible for
destruction when it is no longer possible for any code to use that
instance. Execution of the destructor for the
instance may occur at any time after the instance becomes eligible for
destruction. When an instance is
destructed, the destructors in that instance?s inheritance chain are
called, in order, from most derived to least
derived [Example: The output of the example
Chapter 17 Classes
265
using System;
class A
{
~A() {
Console.WriteLine("A’s destructor");
}
}
class B: A
{
~B() {
Console.WriteLine("B’s destructor");
}
}
class Test
{
static void Main() {
B b = new B();
b = null;
GC.Collect();
GC.WaitForPendingFinalizers();
}
}
is
B?s destructor
A?s destructor
since destructors in an inheritance chain are called in order, from most
derived to least derived. The GC.Collect
method is not required, but may be provided by an implementation. end
example]
Destructors may be implemented by overriding the virtual method Finalize on
System.Object. In any event,
C# programs are not permitted to override this method or call it (or
overrides of it) directly. [Example: For
instance, the program
class A
{
override protected void Finalize() {} // error
public void F() {
this.Finalize(); // error
}
}
contains two errors. end example]
The compiler behaves as if this method, and overrides of it, does not exist
at all. [Example: Thus, this program:
class A
{
void Finalize() {} // permitted
}
is valid and the method shown hides System.Object?s Finalize method. end
example]
For a discussion of the behavior when an exception is thrown from a
destructor, see §23.3.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值