public class Base1
{
public virtual void f()
{
Console.WriteLine("Base1.f()");
}
}
public class Derived1 : Base1
{
// Hides Base1.f() because 'override' was not specified
public new virtual void f()
{
Console.WriteLine("Derived1.f()");
}
}
public class Derived2 : Derived1
{
// Overrides Derived1.f()
public override void f()
{
Console.WriteLine("Derived2.f()");
// Call base method
base.f();
}
}
class Program
{
static void Main(string[] args)
Base1 ob1 = new Derived1();
ob1.f();
Base1 ob2 = new Derived2();
ob2.f();
Derived1 ob3 = new Derived2();
ob3.f();
Derived2 ob4 = new Derived2();
ob4.f();
}
}
// Calls Derived2.f() because Derived2 overrides Derived1().f()
Derived1 ob3 = new Derived2();
ob3.f();
它期待着
Base1 ob2 = new Derived2();
ob2.f();
叫,这是什么原因。
最佳答案
编译时静态分析使用的方法槽取决于变量(或表达式)的类型,而不是实际对象。变量 ob2
的类型为 Base1
,因此使用 Base1
方法槽。然后根据类型(基本上是该插槽上的 vtable)选择正确的覆盖。所以使用了基函数。
要使用derived2 函数,变量(或表达式)必须输入为Derived1
或子类。