“反射”其實就是利用程序集的元數據信息。 反射可以有很多方法,編寫程序時請先導入 System.Reflection 命名空間。
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、根據對象實例創建該對象所屬類的新對象
Type type = protocol.GetType(); //獲取protocol類型
Assembly assembly = Assembly.GetExecutingAssembly(); // 獲取當前程序集
string name = type.FullName;
IProtocol obj = (IProtocol)assembly.CreateInstance(name); //根據類名獲得新對象
注意:由於要用到dynamic ,需要把target 改為4.0 ,如果編譯時出現“找不到編譯動態表達式所需的一個或多個類型。是否缺少引用?”的錯誤,是因為缺少一個引用,在項目里引用Miscorsoft.CSharp類庫,添加后就能編譯成功。
摘自:http://www.cnblogs.com/feiyuhuo/p/5793606.html