“反射”其實就是利用程序集的元數據信息。 反射可以有很多方法,編寫程序時請先導入 System.Reflection 命名空間。
1、假設你要反射一個 DLL 中的類,並且沒有引用它(即未知的類型):
Assembly assembly = Assembly.LoadFile("程序集路徑,不能是相對路徑"); // 加載程序集(EXE 或 DLL)
object obj = assembly.CreateInstance("類的完全限定名(即包括命名空間)"); // 創建類的實例
2、若要反射當前項目中的類(即當前項目已經引用它了)可以為:
Assembly assembly = Assembly.GetExecutingAssembly(); // 獲取當前程序集
object obj = assembly.CreateInstance("類的完全限定名(即包括命名空間)"); // 創建類的實例,返回為 object 類型,需要強制類型轉換
3、也可以為:
Type type = Type.GetType("類的完全限定名");
object obj = type.Assembly.CreateInstance(type);
=======================================================
補充:
1)反射創建某個類的實例時,必須保證使用類的完全限定名(命名空間 + 類名)。Type.GetType 方法返回 null 則意味搜索元數據中的相關信息失敗(反射失敗),請確保反射時使用類的完全限定名。
2)反射功能十分強大,沒有什么不能實現的。若實現“跨程序集”,請使用第一種方法創建類的實例,並反射該實例的字段、屬性、方法、事件... 然后動態調用之。
動態創建帶有構造函數的類實例
System.Reflection.Assembly assembly = System.Reflection.Assembly.Load(path.Value);//通過給定程序集的長格式名稱加載程序集
Type objType = assembly.GetType(path.Value + "." + className.Value);//獲取類型
object[] parameters = new object[4] { null, log, true, className.Value };//構造函數參數
object obj = Activator.CreateInstance(objType, true, System.Reflection.BindingFlags.Default, null, parameters, null, null);//創建類型的實例