c#面试题总结

本文通过一道C#面试题详细解释了构造函数的执行顺序以及虚方法在继承中的调用规则。在创建B类实例时,由于继承关系,首先执行A类的构造函数,其中调用了虚方法PrintFields,由于在B类中被重写,因此实际执行的是B类的PrintFields方法,此时B的构造函数尚未完成,y值默认为0,故输出x=1,y=0。如果在构造完成后直接调用PrintFields,则输出x=1,y=-1。" 105651949,8575142,Java线程池深度解析:Executors工厂与定制线程池,"['线程池', '并发编程', 'Java', '性能优化', 'Executors']


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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值