1、假设你要反射一个 DLL 中的类,并且没有引用它(即未知的类型):
Assembly assembly = Assembly.LoadFile("程序集路径,不能是相对路径"); // 加载程序集(EXE 或 DLL)
dynamic obj = assembly.CreateInstance("类的完全限定名(即包括命名空间)"); // 创建类的实例
2、若要反射当前项目中的类(即当前项目已经引用它了)可以为:
Assembly assembly = Assembly.GetExecutingAssembly(); // 获取当前程序集
dynamic obj = assembly.CreateInstance("类的完全限定名(即包括命名空间)"); // 创建类的实例,返回为 object 类型,需要强制类型转换
3、也可以为:
Type type = Type.GetType("类的完全限定名");
dynamic obj = type.Assembly.CreateInstance(type);
4、不同程序集的话,则要装载调用,代码如下:
System.Reflection.Assembly.Load("程序集名称(不含文件后缀名)").CreateInstance("命名空间.类名", false);
如:
dynamic o = System.Reflection.Assembly.Load("MyDll").CreateInstance("MyNameSpace.A", false);
5、创建的对象没有公有public的构造函数
System.Reflection.BindingFlags flags = System.Reflection.BindingFlags.NonPublic | System.Reflection.BindingFlags.Instance;
System.Globalization.CultureInfo culture = null;
System.Reflection.Assembly assembly = System.Reflection.Assembly.Load("程序集名称(不含文件后缀名)");
Type type = assembly.GetType("命名空间.类名");
Object o = Activator.CreateInstance(type, flags, null, new object[] { 传参1,传参2,等等}, culture);
6、使用反射根据一个字典(key为属性名,value为属性值)设置类,返回一个对象
/// <summary>
/// 遍历返回一个Public、Instance、NonPublic属性都赋值好的类
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dict">key为T类型的属性名,value为对应key的值</param>
/// <returns></returns>
private T GetObject<T>(IDictionary<string, object> dict)
{
Type type = typeof(T);
var obj = Activator.CreateInstance(type);
foreach (var kv in dict)
{
//反射,默认是只能找到public属性,非public属性不会被找到,所以要传入BindingFlags参数来获取protected属性
//先GetProperty根据dict的key找到属性对象,再SetValue这个obj的这个属性值赋值为dict的Value
type.GetProperty(kv.Key, System.Reflection.BindingFlags.Public | System.Reflection.BindingFlags.Instance | System.Reflection.BindingFlags.NonPublic).SetValue(obj, kv.Value);
}
return (T)obj;
}