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();
  • 派生2函数将被调用,但基类函数被调用
    叫,这是什么原因。
  • .net 是否使用 vtables
  • 最佳答案

    编译时静态分析使用的方法槽取决于变量(或表达式)的类型,而不是实际对象。变量 ob2 的类型为 Base1 ,因此使用 Base1 方法槽。然后根据类型(基本上是该插槽上的 vtable)选择正确的覆盖。所以使用了基函数。

    要使用derived2 函数,变量(或表达式)必须输入为Derived1 或子类。

    10-06 03:19