加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

是否可以在C#中使用无类型泛型列表?

发布时间:2020-12-15 08:24:29 所属栏目:百科 来源:网络整理
导读:我正在尝试以下设计但没有成功: abstract class FooT{ abstract T Output { get; }}class Bar{ ListFoo Foos;} 我不喜欢使用数组列表,因为我必须使用不安全的转换来获取类型.我想要输入Foo,以便“输??出”不仅仅是一个对象,在这种情况下我也必须使用不安全
我正在尝试以下设计但没有成功:
abstract class Foo<T>
{
    abstract T Output { get; }
}

class Bar
{
    List<Foo> Foos;
}

我不喜欢使用数组列表,因为我必须使用不安全的转换来获取类型.我想要输入Foo,以便“输??出”不仅仅是一个对象,在这种情况下我也必须使用不安全的强制转换.

正如我的代码目前,我使用Foo无类型输出作为对象.

解决方法

如果我理解正确,你需要一个Foo对象列表,它们有不同类型的输出,对吧?由于这些输出属于不同类型,因此无论如何都必须使用此类输出.

但是,以下想法可能会有所帮助.如何声明一个名为IFoo的非通用接口:1

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);

1您还可以将其设为一个名为Foo的抽象基类,并使其具有Foo< T>从中衍生出来.在这种情况下,您需要使用new关键字标记Foo< T> .Output并使用base.Output访问抽象基础成员.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读