这是一个显示虚拟方法的小代码.
class A { public virtual void F() { Console.WriteLine("A.F"); } } class B: A { public override void F() { Console.WriteLine("B.F"); } } class C: B { new public virtual void F() { Console.WriteLine("C.F"); } } class D: C { public override void F() { Console.WriteLine("D.F"); } } class Test { static void Main() { D d = new D(); A a = d; B b = d; a.F(); b.F(); } }
B.F B.F
我不明白为什么a.F()会打印B.F?
我认为它会打印D.F,因为B类覆盖了A类的F(),然后这个方法被隐藏在C类中使用“new”关键字,然后它再次在D类中被覆盖.所以最后D.F停留.
但它不是那样做的.你能解释为什么要打印B.F吗?
解决方法
A a = d; a.F();
它会找到F()如下.
>首先是A级
>然后在B班
>然后在C班
>然后在D班
现在F()将在A和B中找到.因此将调用B.F().在C类中,F()是不同的(因为它是新的实现,不会从A / B覆盖).所以在第3步中,将找不到c.F().在D类中,它会覆盖由C创建的新函数,因此也无法找到它.
由于新的关键字,结果代码如下(关于虚拟覆盖)
class A { public virtual void F() { Console.WriteLine("A.F"); } } class B: A { public override void F() { Console.WriteLine("B.F"); } } class C: B { public virtual void F1() { Console.WriteLine("C.F"); } } class D: C { public override void F1() { Console.WriteLine("D.F"); } }