很多人对构造方法都存在误解,这种误解来源于对象的创建语法和一些书对其模糊不清的说明。
当然,在大多情况下这个误解并不会影响您的工作,但是这并不表示您就可以不去了解事实的真相。
好了,我们就假设对象是由构造方法来创建的,我们看看下面这段代码会告诉我们什么。
执行结果是:
Base...
Class1 Method...
Class1...
也就是说Method方法在Class1构造方法之前就被正确调用了,而Method并不时静态方法,那么我们该怎么理解呢?
在创建一个引用类型的实例时,系统将执行以下3个步骤:首先为该实例分配内存,然后初始化对象的附加成员(方法指针表和SyncBlockIndex),最后调用类型的实例构造器设置对象的初始状态。
也就是说在调用构造方法前,对象就已经被创建,构造方法只是一种特殊的由系统调用,用来初始化对象状态的方法。对象并不是由构造方法创建。同理,析构方法也只是用来清除一些必要的资源,而不是销毁对象。
当然,在大多情况下这个误解并不会影响您的工作,但是这并不表示您就可以不去了解事实的真相。
好了,我们就假设对象是由构造方法来创建的,我们看看下面这段代码会告诉我们什么。
abstract class Base
{
public Base()
{
Console.WriteLine("Base...");
Method();
}
public abstract void Method();
}
class Class1 : Base
{
public Class1()
{
Console.WriteLine("Class1...");
}
public override void Method()
{
Console.WriteLine("Class1 Method...");
}
static void Main(string[] args)
{
new Class1();
}
}
{
public Base()
{
Console.WriteLine("Base...");
Method();
}
public abstract void Method();
}
class Class1 : Base
{
public Class1()
{
Console.WriteLine("Class1...");
}
public override void Method()
{
Console.WriteLine("Class1 Method...");
}
static void Main(string[] args)
{
new Class1();
}
}
执行结果是:
Base...
Class1 Method...
Class1...
也就是说Method方法在Class1构造方法之前就被正确调用了,而Method并不时静态方法,那么我们该怎么理解呢?
在创建一个引用类型的实例时,系统将执行以下3个步骤:首先为该实例分配内存,然后初始化对象的附加成员(方法指针表和SyncBlockIndex),最后调用类型的实例构造器设置对象的初始状态。
也就是说在调用构造方法前,对象就已经被创建,构造方法只是一种特殊的由系统调用,用来初始化对象状态的方法。对象并不是由构造方法创建。同理,析构方法也只是用来清除一些必要的资源,而不是销毁对象。