Рассмотрим следующий код (он немного длинный, но, надеюсь, вы можете следовать):
class A
{
}
class B : A
{
}
class C
{
public virtual void Foo(B b)
{
Console.WriteLine("base.Foo(B)");
}
}
class D: C
{
public override void Foo(B b)
{
Console.WriteLine("Foo(B)");
}
public void Foo(A a)
{
Console.WriteLine("Foo(A)");
}
}
class Program
{
public static void Main()
{
B b = new B();
D d = new D ();
d.Foo(b);
}
}
Если вы считаете, что выход этой программы является "Foo (B)", то вы будете в той же лодке, что и я: совершенно неправильно! Фактически, он выводит "Foo (A)"
Если я удалю виртуальный метод из класса C
, он будет работать так, как ожидалось: "Foo (B)" - это вывод.
Почему компилятор выбирает версию, которая принимает A
, когда B
является более производным классом?