假设我有一个包含整数的列表 (var identifiers = Enumerable.Empty<int>()
).
通过这个列表,我可以将各个项目转换为另一种类型:
var castedIdentifiersLong = identifiers.Cast<long>();
var castedIdentifiersString = identifiers.Cast<string>();
我们可以用Select<TSource, TTarget>()
使用隐式转换:
var mappedIdentifiersLong = identifiers.Select<int, long>(x => x);
var mappedIdentifiersString = identifiers.Select<int, string>(x => x);
显然最后一条语句失败了,因为int
不能隐式转换为string
。这是故意的。
有没有一种方法可以定义扩展方法(比如CastImplicitly<T>
),我只能定义两个泛型类型之一,并且它会从源可枚举中找出第一个类型?
var unwanted = identifiers.ImplicitCast<string>();
var wanted = identifiers.ImplicitCast<long>();
在这种情况下unwanted
甚至不应该编译,因为int
不能隐式转换为string
。但另一方面,wanted
应该编译,因为它可以隐式转换为long
.
有没有一种方法可以定义扩展方法(比如CastImplicitly<T>
),我只能定义两个泛型类型之一,并且它会从源可枚举中找出第一个类型?
如果输入是通用的则不会。编译器无法部分推断泛型参数 - 您要么必须指定所有泛型参数,要么不指定任何参数,然后让编译器推断。
即使你could,编译器仍然不允许泛型类型之间的隐式转换。
如果您希望编译器在编译时识别无效的强制转换,您可以执行显式强制转换:
var mappedIdentifiersString = identifiers.Select(x => (string)x); // fails at compile time if x is an int.
可能抓不到every编译时可能存在无效强制转换(例如,强制转换为object
在编译时总是允许的)但它对于您的特定情况确实失败int
to string
设想。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)