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