C#在运行时传递泛型

C#在运行时传递泛型,第1张

概述我有一个如下的方法: public IEnumerable<T> GetControls<T>() : where T : ControlBase{ // removed.} 然后我创建了一个类: public class HandleBase<TOwner> : ControlBase : TOwner{ // Removed} 我想要打电话 GetControls<Handle 我有一个如下的方法:
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.

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

总结

以上是内存溢出为你收集整理的C#在运行时传递泛型全部内容,希望文章能够帮你解决C#在运行时传递泛型所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1262040.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-08
下一篇 2022-06-08

发表评论

登录后才能评论

评论列表(0条)

保存