我观察到只要编译器遇到如下的委托声明:
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正确吗?
我不熟悉框架的这一部分,但 Reflector 给出了以下定义BeginInvoke:
[MethodImpl(0, MethodCodeType=MethodCodeType.Runtime)]
public virtual IAsyncResult BeginInvoke(string myString, AsyncCallback callback, object @object);
Run Code Online (Sandbox Code Playgroud)
我的眼睛被这个属性吸引了MethodImpl。MethodCodeType.Runtime方法:
指定方法实现由运行时提供。
所以我猜这是virtual因为运行时会覆盖它的功能。并且运行时可以轻松通过该类sealed。