首页 / C# / c#-为什么后续调用是不明确的?
c#-为什么后续调用是不明确的?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c#-为什么后续调用是不明确的?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2283字,纯文字阅读大概需要4分钟。
内容图文
![c#-为什么后续调用是不明确的?](/upload/InfoBanner/zyjiaocheng/667/b2fb11e332db4b2a8a3e3260d4a410b1.jpg)
由于编译器需要方法SetAll(PropertyInfo,int),因此以下调用将失败.
var infos = GetType().GetProperties(BindingFlags.Instance | BindingFlags.Public);
var setters = infos.Select(SetAll); // no overload matches delegate.
private Action SetAll(PropertyInfo info, object obj) => () => info.SetValue(this, obj);
因此,这意味着编译器无法以任何方式使用此重载.它不能将int转换为对象.
考虑到这一点,为什么下面的调用不明确?
var b = infos.Select(SetAll); // ambiguous between Select<PropertyInfo, int, Action>
// and Select<PropertyInfo, Action>
private Action SetAll(PropertyInfo info, object obj) => () => info.SetValue(this, obj);
private Action SetAll(PropertyInfo info) => () => info.SetValue(this, null);
如果编译器无法以任何方式对对象使用重载,那么为什么它在这里仍然挣扎?
这是我的实际代码.我可以轻松解决这个问题,但我只是好奇.
var infos = GetType().GetProperties(BindingFlags.Instance | BindingFlags.Public);
if (useDefaultsOnReset)
{
var defaults = infos.Select(GetAll);
_resetters = infos.Zip(defaults, SetAll).ToArray();
}
else
{
_resetters = infos.Select(SetAll).ToArray(); // error
}
private object GetAll(PropertyInfo info) => info.GetValue(this);
private Action SetAll(PropertyInfo info, object obj) => () => info.SetValue(this, obj);
private Action SetAll(PropertyInfo info) => () => info.SetValue(this, null);
解决方法:
这是因为System.Func< in T1,in T2,out TResult>.在参数类型上是相反的.这由相应类型参数上的in修饰符表示.这意味着它与任何接受类型为T1或任何类型T1的参数的函数匹配,并且类型为T2或任何类型T2的参数都可以匹配.您的第一个签名与不包含索引的Enumerable.Select重载匹配.但是,您的第二个签名实际上与Enumerable.Select的重载匹配,该重载确实包含了索引,因为int可分配给对象.
为了证明这一点.只需创建一个任意类,然后像这样更改程序即可.
private Action SetAll(PropertyInfo info, A a) => () => info.SetValue(this, obj);
private Action SetAll(PropertyInfo info) => () => info.SetValue(this, null);
class A {}
您将看到错误消失,因为int不可分配给A.
正如评论中所讨论的,我没有考虑到皱纹.引用关系之间,引用类型之间和非约束类型之间都存在逆变关系,但这些泛型关系在使用int和object的委托之间直接分配时特别不适用于
给定
Func<int, Action> f;
Func<object, Action> g;
以下都是错误
g = f;
f = g;
但是,如果我们将int替换为A类
Func<A, Action> f;
Func<object, Action> g;
第一个是错误,因为对象不是A,但是第二个如上所述成功.
g = f;
f = g;
内容总结
以上是互联网集市为您收集整理的c#-为什么后续调用是不明确的?全部内容,希望文章能够帮你解决c#-为什么后续调用是不明确的?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。