当内部类被密封时,为什么调用BeginInvoke和EndInvoke是虚拟的?

Dev*_*hot 9 c# delegates

我观察到只要编译器遇到如下的委托声明:

public delegate string StringOperation(string myString);

然后编译器生成以下代码:

public sealed class StringOperation: System.MulticastDelegate  
{  
   public StringOperation (object target, int method);  
   public virtual void Invoke(string myString);  
   public virtual IAsyncResult BeginInvoke(string myString,  
   AsyncCallback callback, object obj);  
   public virtual void EndInvoke(IAsyncResult result);  
}
Run Code Online (Sandbox Code Playgroud)

我的问题是,为什么virtual当类本身是一个sealed类时它会生成方法?

没有必要创造virtual方法,因为我们不能override正确吗?

Pat*_*man 0

我不熟悉框架的这一部分,但 Reflector 给出了以下定义BeginInvoke

[MethodImpl(0, MethodCodeType=MethodCodeType.Runtime)]
public virtual IAsyncResult BeginInvoke(string myString, AsyncCallback callback, object @object);
Run Code Online (Sandbox Code Playgroud)

我的眼睛被这个属性吸引了MethodImplMethodCodeType.Runtime方法:

指定方法实现由运行时提供。

所以我猜这是virtual因为运行时会覆盖它的功能。并且运行时可以轻松通过该类sealed