我正在编写一个过滤器函数来返回从更大的超类型集合(例如对象)中指定的特定类型.这个想法是我给你一个可枚举的,你举例说明了所有的字符串.你可以这样写,没有泛型:
public static IEnumerable Filter(IEnumerable source, Type type)
{
List<object> results = new List<object>();
foreach(object o in source)
{
if(o != null && o.GetType() == type)
{
results.Add(o);
}
}
return results;
}
Run Code Online (Sandbox Code Playgroud)
如果我们想要返回泛型,有几种不同的方法可以解决它.
作为直接端口:
public static IEnumerable<TResult> Filter<TResult>
(IEnumerable source, Type type)
Run Code Online (Sandbox Code Playgroud)
传递'示例':
IEnumerable<TResult> Filter<TResult>
(IEnumerable source, TResult resultType)
Run Code Online (Sandbox Code Playgroud)
最终我认为最干净的是:
public static IEnumerable<T> Filter<T>(IEnumerable source)
Run Code Online (Sandbox Code Playgroud)
第二种类型将完全使用参数调用(并推断类型):
Filter(myList, "exampleString");
Run Code Online (Sandbox Code Playgroud)
作为最终版本,将使用类型说明符调用:
Filter<string>(myList);
Run Code Online (Sandbox Code Playgroud)
强类型返回泛型函数的适当方法是什么,其中返回类型不会自动隐含在签名中?(为什么?)
(编辑注意:我们的输入没有输入,例如IEnumerable <T>.最好是IEnumerable.这个函数将Ts退出其他类型的整个集合.)
Linq中包含的以下扩展方法可以满足您的需求:
IEnumerable<T> OfType<T>(this IEnumerable enumerable);
Run Code Online (Sandbox Code Playgroud)
这是一个用法示例:
List<object> objects = //...
foreach(string str in objects.OfType<string>())
{
//...
}
Run Code Online (Sandbox Code Playgroud)
如您所见,他们使用泛型参数作为返回类型说明符.这比使用Type或字符串更简单,更安全,并返回非类型安全枚举.