这是一个显示虚拟方法的小代码.
- 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"); }
- }