У меня пока нет ответа, но у меня есть, как мне кажется, немного более понятная программа для демонстрации странности:
using System;
delegate void MyDelegate();
public class Program
{
static void Main(string[] args)
{
var c = new MyChild();
c.DisplayOddity();
Console.ReadLine();
}
}
public class MyParent
{
public virtual void X()
{
Console.WriteLine("Executing MyParent.X");
}
}
public class MyChild : MyParent
{
public void DisplayOddity()
{
MyDelegate md = base.X;
Console.WriteLine("Calling Invoke()");
md.Invoke(); // Executes base method... fair enough
Console.WriteLine("Calling BeginInvoke()");
md.BeginInvoke(null, null); // Executes overridden method!
}
public override void X()
{
Console.WriteLine("Executing MyChild.X");
}
}
Это не связано с рекурсивными вызовами. В результате все та же странность:
Calling Invoke()
Executing MyParent.X
Calling BeginInvoke()
Executing MyChild.X
(Если вы согласны с тем, что это более простое воспроизведение, смело заменяйте код в исходном вопросе, и я удалю его из своего ответа:)
Если честно, для меня это похоже на ошибку. Я еще немного покопаюсь.