C#泛型方法,可以推断泛型类型定义中参数的类型吗?
发布时间:2020-12-15 17:19:32 所属栏目:百科 来源:网络整理
导读:有没有办法让以下(不编译)代码运行?我还没有找到解决方案. public class Factory{ public static T GetT(V v) where T : BaseClassV { T someObject = DIContainer.ResolveT(); someObject.Set(v); }} T是普通的泛型类型参数,用于定义泛型方法“Get”,但具
有没有办法让以下(不编译)代码运行?我还没有找到解决方案.
public class Factory{ public static T Get<T>(V v) where T : BaseClass<V> { T someObject = DIContainer.Resolve<T>(); someObject.Set(v); } } T是普通的泛型类型参数,用于定义泛型方法“Get”,但具有包含泛型本身的类型约束. 它可以通过在V上用另一个约束定义Get as Get方法来工作.但是然后调用将是Factory.Get< A< B>,B>(….)这不是很好,因为B的声明是有两次. 谢谢! 解决方法
与C模板不同,您可以拥有
“template templates”或
“partial specialization”,C#泛型参数只能在声明站点上进行一次深入,而泛型约束只能告诉您有关谱系的信息,仅此而已.如果你想能够引用你的一个泛型参数的泛型参数,那么唯一的方法就是在你的例子中,通过对继承沿袭的通用约束(T:BaseClass< V>),然后还必须在通用签名中标识V.你需要像下面这样的东西.
public class Factory{ public static T Get<T,V>(V v) where T : BaseClass<V> { T someObject = DIContainer.Resolve<T>(); someObject.Set(v); } } 我在这里添加的是方法签名的通用参数V.同样,如果您没有基类来锚定V,那么您将无法对您的情况做很多事情.例如,如果T本身的运行时类型是通用的,而不是它的基类,那么您将陷入困境,如下面的示例所示,这将无法编译. public class Factory{ public static T Get<T,V>(V v) where T : T<V> { T someObject = DIContainer.Resolve<T>(); someObject.Set(v); } } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容