本文介绍了即使签名匹配,也无法将一种类型的委托分配给另一种类型的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!
问题描述
我病态的好奇心让我想知道为什么以下失败:
My morbid curiosity has me wondering why the following fails:
// declared somewhere
public delegate int BinaryOperation(int a, int b);
// ... in a method body
Func<int, int, int> addThem = (x, y) => x + y;
BinaryOperation b1 = addThem; // doesn't compile, and casting doesn't compile
BinaryOperation b2 = (x, y) => x + y; // compiles!
推荐答案
C# 对结构"类型的支持非常有限.特别是,您不能将一种委托类型转换为另一种简单地,因为它们的声明是相似的.
C# has very limited support for "structural" typing. In particular, you can't cast from one delegate-type to another simply because their declarations are similar.
来自语言规范:
C# 中的委托类型是名称等效的,不是结构上的相等的.具体来说,两个不同的委托类型具有相同的参数列表和返回类型被认为是不同的代表类型.
Delegate types in C# are name equivalent, not structurally equivalent. Specifically, two different delegate types that have the same parameter lists and return type are considered different delegate types.
尝试以下之一:
// C# 2, 3, 4 (C# 1 doesn't come into it because of generics)
BinaryOperation b1 = new BinaryOperation(addThem);
// C# 3, 4
BinaryOperation b1 = (x, y) => addThem(x, y);
var b1 = new BinaryOperation(addThem);
这篇关于即使签名匹配,也无法将一种类型的委托分配给另一种类型的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!
本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!