我正在尝试以下设计但没有成功:
abstract class Foo<T>
{
    abstract T Output { get; }
}
class Bar
{
    List<Foo> Foos;
}
我不喜欢使用数组列表,因为我必须使用不安全的转换来获取类型.我想要输入Foo,以便"输出"不仅仅是一个对象,在这种情况下我也必须使用不安全的强制转换.
正如我的代码目前,我使用Foo无类型输出作为对象.
如果我理解正确,你想要一个Foo具有不同类型Outputs 的对象列表,对吧?由于这些输出属于不同类型,因此无论如何都必须使用此类输出.
但是,以下想法可能会有所帮助.如何声明一个名为的非泛型接口IFoo:¹
public interface IFoo
{
    object Output { get; }
}
然后在抽象类中实现它:
abstract class Foo<T> : IFoo
{
    abstract T Output { get; }
    object IFoo.Output { get { return Output; } }
}
然后你可以声明一个IFoos 的列表:
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>从中派生出来.在这种情况下,你就需要标记Foo<T>.Output与new关键字,并使用base.Output访问抽象基成员.