Bra*_*her 4 c# generics templates runtime
是否可以在运行时实例化模板类,例如:
Type type = Type.GetType("iTry.Workflow.Person");
WorkflowPropertyViewModel<type> propViewModel = new WorkflowPropertyViewModel<type>();
Run Code Online (Sandbox Code Playgroud)
这显然不起作用.还有其他方法吗?
Generic类如下所示:
public class WorkflowPropertyViewModel<T> : IProperty<T>
{
public Task<T> ValueAsync
{
get;
set;
}
public T Value
{
get;
set;
}
public IQueryable<T> PossibleItems
{
get;
set;
}
}
Run Code Online (Sandbox Code Playgroud)
给定Type对象,您可以创建任何类型的对象:
object o = Activator.CreateInstance(type);
Run Code Online (Sandbox Code Playgroud)
这假定类型具有默认构造函数.还有其他Activator方法用于传递构造函数参数:
http://msdn.microsoft.com/en-us/library/wccyzw83.aspx
为了获得特定的泛型类型,您可以在泛型类型定义上调用MakeGenericType
http://msdn.microsoft.com/en-us/library/system.type.makegenerictype.aspx
所以把它完全放在一起看起来像:
var type = Type.GetType("iTry.Workflow.Person");
var genericType = typeof(WorkflowPropertyViewModel<>).MakeGenericType(type);
var o = Activator.CreateInstance(genericType);
Run Code Online (Sandbox Code Playgroud)
是的,您可以使用仅在运行时已知的类型实例化泛型类,例如:
public class A { }
public class U<T> {
public T X { get; set; }
}
static void Main(string[] args) {
Type a = typeof(A);
Type u = typeof(U<>);
dynamic uOfA = Activator.CreateInstance(u.MakeGenericType(a));
uOfA.X = new A();
Console.WriteLine(uOfA.GetType());
Console.WriteLine(uOfA.X.GetType());
}
Run Code Online (Sandbox Code Playgroud)
但是,此代码片段使用了反射和动态类型,这两者都可能会导致很多维护问题,因此您最好非常小心地使用它们或找到更简单的解决方案。