4

我有两个通用委托,我试图定义编译器抱怨它们是重复的,但在我看来是完全不同的。我在做什么/理解错误?

delegate TReturn foo<TParameter, out TReturn>(TParameter parameter, IItem item);

delegate TReturn foo<TParameter, out TReturn>(TParameter parameter, int field, IItem item);

如果我向第二个委托添加一个新的通用参数,一切正常。

delegate TReturn foo<TParameter, TField, out TReturn>(TParameter parameter, TField field, IItem item) where TField struct

但这似乎不正确。我将始终为字段传递一个 int - 它不应该是通用的。

4

2 回答 2

5

代表不是方法。他们知道如何调用方法,但他们本身不是方法(委托是一个object),因此不能像方法一样被重载。

请参阅这篇文章,了解为什么它不可能。

于 2012-07-02T16:01:17.027 回答
3

使用delegate关键字时,幕后发生的是编译器根据其定义生成一个类。因此,当您像这样定义委托时:

delegate TReturn foo<TParameter, out TReturn>(TParameter parameter, IItem item);

从中生成以下类:

class foo<TParameter, out TReturn> : MulticastDelegate
{
    public void Invoke(TParameter parameter, IItem item) { ... }
    ....
}

如您所见,当您有两个具有相同名称和相同泛型参数的委托时,会导致生成两个相同的类,这当然是不可接受的。

我推荐 Jeffrey Richter 的一本通过 C# 编写的优秀书籍CLR,它更清楚地揭示了像这样的幕后东西——等等。

于 2012-07-02T16:04:08.773 回答