1

下面提到的场景将很好地清除情况。我愿意调用 xDerived1 类的虚方法。虽然我可以调用 xBase 类方法和 xDerived2 类方法。

((xDerived1)xDer2).myMethod(); //覆盖 void myMethod

请帮帮我。

static void Main(string[] args)
        {
            xDerived2 xDer2 = new xDerived2();
            xDer2.myMethod();
            ((xBase)xDer2).myMethod();
            ((xDerived1)xDer2).myMethod();
}


public class xBase
        {
            public virtual void myMethod()
            {
                Console.WriteLine("virtual void myMethod");
            }
        }
    public class xDerived1 :xBase
    {
        public new virtual void myMethod()
        {
            Console.WriteLine("new virtual void myMethod");
        }
    }
    public class xDerived2 : xDerived1
    {
        public override void myMethod()
        {
            Console.WriteLine("override void myMethod");
        }
    }
4

2 回答 2

1

我得到了这个问题的解决方案,我们可以通过使用反射来调用它,如下所述:

xDerived2 child = new xDerived2();

            Action parentPrint = (Action)Activator.CreateInstance(typeof(Action), child, typeof(xDerived1).GetMethod("myMethod").MethodHandle.GetFunctionPointer());
            parentPrint.Invoke();
于 2013-09-24T09:40:36.663 回答
0

根本不可能xDerived1::myMethodxbase. new关键字导致定义新方法,因此xDerived::myMethodxbase::myMethod. 为了调用该方法,您需要将其转换为xDerived1.

xbase local1 = ...;
xDerived1 local2 = local1 as xDerived;
if (local2 != null) { 
  local2.myMethod();
}
于 2013-09-23T13:22:02.133 回答