我有一个方法 Foo4,它接受 Func<> 类型的参数。如果我传递匿名类型的参数,我不会收到任何错误。但是,如果我创建并传递一个“委托(delegate)”类型的对象,该对象引用具有正确签名的方法,则会出现编译器错误。我无法理解为什么在这种情况下会出现错误。
class Learn6
{
delegate string Mydelegate(int a);
public void Start()
{
Mydelegate objMydelegate = new Mydelegate(Foo1);
//No Error
Foo4(delegate(int s) { return s.ToString(); });
//This line gives compiler error.
Foo4(objMydelegate);
}
public string Foo1(int a) { return a.ToString();}
public void Foo4(Func<int, string> F) { Console.WriteLine(F(42)); }
}
最佳答案
如果您直接传递对方法的引用,它会起作用:
Foo4(Foo1);
这是因为具有相同形状的实际委托(delegate)本质上不被认为是兼容的。如果契约是隐式的,编译器会推断契约并将它们匹配起来。如果它们是显式的(例如声明的类型),则不会执行任何推断 - 它们只是不同的类型。
类似于:
public class Foo
{
public string Property {get;set;}
}
public class Bar
{
public string Property {get;set;}
}
我们可以看到这两个类具有相同的签名并且是“兼容的”,但是编译器将它们视为两种不同的类型,仅此而已。
关于c# - 使用 Func<> 参数将委托(delegate)对象传递给方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1648082/