我的数据库中有一个表,用于管理我的应用程序之间的关系.它的本质是非常基本的 - parentType,parentId,childType,childId ...... all as int.之前我已经完成了这个设置,但是当我有6个不同的表我试图链接时,我使用了一个开关/案例设置.现在我有30个表,我正在尝试这样做,我希望能够这样做,而无需在我的switch命令中写入30个案例条目.
有没有办法可以使用字符串引用.Net类?我知道这是无效的(因为我尝试了几种变体):
Type t = Type.GetType("WebCore.Models.Page");
object page = new t();
我知道如何获取对象的类型,但是我如何动态使用它来创建一个新对象?
Jas*_*zek 57
此链接应该有所帮助:
http://msdn.microsoft.com/en-us/library/system.activator.createinstance(VS.71).aspx
Activator.CreateInstance将创建指定类型的实例.
你可以用这样的泛型方法包装它:
public T GetInstance<T>(string type)
{
    return (T)Activator.CreateInstance(Type.GetType(type));
}
Jud*_*ngo 13
如果调用者知道类型,则使用Activator.CreateInstance会有更好,更快的方法:您可以在方法上使用泛型约束来指定它具有默认的无参数构造函数.
这样做是类型安全的,不需要反射.
T CreateType<T>() where T : new()
{
   return new T();
}
小智 10
public static T GetInstance<T>(params object[] args)
{
     return (T)Activator.CreateInstance(typeof(T), args);
}
我会使用Activator.CreateInstance()而不是强制转换,因为Activator有一个泛型的构造函数.
以下是它的工作原理示例:
using System;
using System.Runtime.Remoting;
class Program
{
    static void Main()
    {
        ObjectHandle o = Activator.CreateInstance("mscorlib.dll", "System.Int32");
        Int32 i = (Int32)o.Unwrap();
    }
}