的例如,如果我理解正确的话,你希望它有不同类型的Output
小号Foo
对象的列表,对不对?由于这些输出具有不同的类型,因此无论如何您都必须使用强制转换。
但是,下面的想法可能会有所帮助。你怎么样声明一个名为IFoo
非通用接口:¹
public interface IFoo
{
object Output { get; }
}
,然后实现它在你的抽象类:
abstract class Foo<T> : IFoo
{
abstract T Output { get; }
object IFoo.Output { get { return Output; } }
}
然后你就可以申报IFoo
个清单:
class Bar
{
List<IFoo> Foos;
}
访问这些foos时,您可以通过界面检索输出为对象:
var myObject = Foos[0].Output; // type ‘object’
,或者你可以尝试去发现真正的类型,如果你知道它只能是一些特定类型之一:
if (Foos[0] is Foo<string>)
var myString = ((Foo<string>) Foos[0]).Output; // type ‘string’
你甚至可以做基于类型过滤,例如:
// Type ‘IEnumerable<string>’ (rather than ‘IEnumerable<object>’)!
var stringFoos = Foos.OfType<Foo<string>>().Select(f => f.Output);
¹您也可以让这个所谓的Foo
抽象基类和具有Foo<T>
从中获得。在这种情况下,您需要使用new
关键字标记Foo<T>.Output
,并使用base.Output
访问抽象基础成员。
完全重复:http://stackoverflow.com/questions/353126/c-multiple-generic-types-in-one-list – GameZelda 2010-09-01 01:30:56