在.NET中,委托的内部实现是什么?

发布于 2024-10-11 03:35:44 字数 527 浏览 11 评论 0原文

我知道代表的声明是这样的:

public delegate int PerformCalculation(int x, int y);

但是,肯定还有更多的事情发生。委托的目的是提供指向方法的指针,为此,您可以在委托中封装对该方法的引用。

该引用保存在什么样的结构中(在委托内部)?我还了解您可以在委托中封装对多个方法的引用。这是否意味着委托中有一个数组保存这些?

另外,委托中定义了哪些方法等。当您使用简洁的声明委托时,到底发生了什么

public delegate int PerformCalculation(int x, int y);

编辑:一些澄清。当您声明委托时,编译器会自动创建一个继承自 System.MulticastDelegate 的密封类。如果您使用 ildasm 查看程序集,您可以看到这一点。这个整齐。基本上,通过一条语句,您将在编译时为您生成一个全新的类,并且它具有您需要的所有功能。

I understand that a declaration of a delegate is something like this:

public delegate int PerformCalculation(int x, int y);

However, there must be more going on. The purpose of the delegate is to provide a pointer to a method, and to do that you encapsulate the reference to the method in the delegate.

What kind of structure is this reference held in (internally in the delegate)? I also understand that you can encapsulate a reference to multiple methods in a delegate. Does this mean that there is an array in the delegate that holds these?

Also, what methods are defined in the delegate, etc. What is really happening when you declare a delegate with the terse:

public delegate int PerformCalculation(int x, int y);

?

EDIT: Some clarification. When you declare a delegate, the compiler automatically creates a sealed class that inherits from System.MulticastDelegate for you. You can see this if you look at your assembly with ildasm. This neat. Basically, with one statement, you are getting an entire new class generated for you at compile time, and it has all the functionality you need.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

风轻花落早 2024-10-18 03:35:44

在内部它是一个引用类型,与类非常相似。转录起来是这样的:

public /* delegate */ class PerformCalculation : MulticastDelegate {
    public PerformCalculation(object target, IntPtr method) {}
    public virtual void Invoke(int x, int y) {}
    public virtual IAsyncResult BeginInvoke(int x, int y, AsyncCallback callback, object state) {}
    public virtual void EndInvoke(IAsyncResult result) {}
}

我将这些成员的实现留空,它们实际上映射到 CLR 中的代码。编译器根据委托声明的签名动态生成方法签名。请注意 x 和 y 参数。 JIT 编译器使用 += 或 -= 语法帮助调用构造函数,它知道委托目标方法的内存地址。编译器自动生成target参数值,具体取决于目标方法是否是静态的。这两个参数映射到 (Multicast)Delegate.Target 和 Method 属性。实际的基类实例可以是 Delegate 也可以是 MulticastDelegate,具体取决于订阅的目标数量。

这里有很多秘密酱汁。

Internally it's a reference type, quite similar to a class. Transcribed it looks like this:

public /* delegate */ class PerformCalculation : MulticastDelegate {
    public PerformCalculation(object target, IntPtr method) {}
    public virtual void Invoke(int x, int y) {}
    public virtual IAsyncResult BeginInvoke(int x, int y, AsyncCallback callback, object state) {}
    public virtual void EndInvoke(IAsyncResult result) {}
}

I left the implementations of these members empty, they are actually mapped to code in the CLR. The compiler dynamically generates the method signatures, depending on the signature of the delegate declaration. Note the x and y arguments. The JIT compiler helps to get the constructor called, using the += or -= syntax, it knows the memory address of the delegate target method. The compiler automatically generated the target argument value, depending on whether the target method was static or not. The two arguments map to the (Multicast)Delegate.Target and Method properties. The actual base class instance can be either Delegate or MulticastDelegate, depending on how many targets were subscribed.

Lots of secret sauce going on here.

新一帅帅 2024-10-18 03:35:44

所有委托都继承自 System.Delegate 类型,该类型持有 < a href="http://msdn.microsoft.com/en-us/library/system.delegate.target.aspx" rel="noreferrer">目标 和 方法。更准确地说,它们继承自 System.MultiCastDelegate ,后者继承自 系统.委托

All delegates inherit from the System.Delegate type which hold a Target and Method. More precisely they inherit from System.MultiCastDelegate which inherits from System.Delegate.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文