析構函數被轉換為Finalize函數。在C#文檔中也制定了這條信息。 Finalize函數的調用源於Object。文本"hi"不會顯示,因為只要運行時決定了,這個函數就會 被調用。我們所知道的全部是——在對象“死亡”時Finalize就會被調用。因此, 無論何時一個對象“死亡”,它都會調用Finalize。沒有辦法銷毀任何事物,包括.Net對象在 內。
a.cs
class zzz
{
public zzz()
{
}
public zzz(int i)
{
}
public static void Main()
{
}
~zzz()
{
System.Console.WriteLine("hi");
}
}
class yyy : zzz
{
}
a.il
.class private auto ansi yyy extends zzz
{
.method public hidebysig specialname rtspecialname instance void .ctor() il managed
{
ldarg.0
call instance void zzz::.ctor()
ret
}
}
在上 面的代碼中,我們只顯示了類yyy。即使我們有2個構造函數和1個析構函數,類yyy只接收默認的無參構造 函數。因此,派生類不會從基類中繼承構造函數和析構函數。
a.il
.assembly mukhi {}
.class private auto ansi zzz extends [mscorlib]System.Object
{
.method public hidebysig static void vijay() il managed
{
.entrypoint
call void yyy::abc()
ret
}
}
.class private auto ansi yyy extends [mscorlib] System.Array
{
.method public hidebysig static void abc() il managed
{
ldstr "hi"
call void [mscorlib]System.Console::WriteLine(class System.String)
ret
}
}
Output
hi