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

C#在运行时传递泛型

发布时间:2020-12-15 04:06:43 所属栏目:百科 来源:网络整理
导读:我有一个如下的方法: public IEnumerableT GetControlsT() : where T : ControlBase{ // removed.} 然后我创建了一个类: public class HandleBaseTOwner : ControlBase : TOwner{ // Removed} 我想要打电话 GetControlsHandleBasethis.GetType(); 它将使用
我有一个如下的方法:
public IEnumerable<T> GetControls<T>()
 : where T : ControlBase
{
 // removed.
}

然后我创建了一个类:

public class HandleBase<TOwner> : ControlBase
 : TOwner
{
 // Removed
}

我想要打电话

GetControls<HandleBase<this.GetType()>>;

它将使用THIS类的类型传递给HandleBase.这将基本上获得拥有这种类型的所有者的所有HandleBase.

我该如何实现?

编辑:

我使用的是.NET 2.0,因此大于2.0的解决方案将无法正常工作.

这个想法是让ControlBase有一个其他ControlBase为“children”的集合.然后可以根据GetControls< T>()的类型进行查询.这将允许我,例如,获得一个Shape的所有HandleBase.然后我可以把所有这些,并设置Visible = false或与他们做别的事情.因此,我可以操纵一个特定类型的子类用于集合.

HandleBase< TOWNER>需要TOwner,因为它引用了“拥有类型”.所以你只能添加任何将HandleBase扩展到Shape的东西.合理?

感谢所有的帮助!

解决方法

您可以通过在编译时指定类型或使用反射来执行此操作.

你可以用这样的反思来做:

typeof(SomeClass).GetMethod("GetControls")
    .MakeGenericMethod(typeof(HandleBase<>).MakeGenericType(GetType()))
    .Invoke(someObject,null);

注意它会返回一个对象;您将无法将其转换为IEnumerable< T> (除非你知道T在编译时,在这种情况下没有意义).您可以将其转换为IEnumerable.

但是,这是一个坏主意.你可能有更好的解决方案请提供更多的细节.

(编辑:李大同)

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

    推荐文章
      热点阅读