using System;
class A
{
public A()
{
PrintFields();
}
public virtual void PrintFields(){}
}
class B:A
{
int x=1;
int y;
public B()
{
y=-1;
}
public override void PrintFields()
{
Console.WriteLine("x={0},y={1}",x,y);
}
当使用new B()创建B的实例时,产生什么输出?
答:X=1,Y=0
答案具体解释:
由于构造B之前,先运行变量,y没有明白赋值,默觉得0。运行B的构造函数,由于B继承A。所以先运行A的构造函数。A构造函数调用的PrintFields方法在A类里是虚函数。它的实现是在B类,所以运行B类的PrintFields方法,结果输出。
尽管继续运行完B的构造函数,使y的值是-1.但结果之前已经输出。
1-8代表了new B的时候,程序的运行过程。
class A
{
public A()//④
{
PrintFields();//⑤,发现被重写→⑥
}
public virtual void PrintFields() { }
}
class B : A
{
int x = 1;//①
int y;//②
public B()//③,发现继承了A。立即运行A的构造函数
{
y = -1;//⑧,到此。创建对象完成
}
public override void PrintFields()//⑥
{
Console.WriteLine("x={0},y={1}", x, y);//⑦,输出,此时:x=1,y=0
}
}
当程序实例化B时,由于继承关系,,B会先调用其父类的构造方法,,而A的构造中又调用 了 PrintFields 在A中 printFields是虚方法,,所以会调用B中的重写 当调用 PrintFields时 B的构造还未运行,所以y=0而不是-1.所以输出结果是x=1,y=0 假设 B b=new B();b.PrintFields();那么输出结果就是x=1,y=-1