看多java的反射使用,就想列出c#的反射使用
出处:
http://www.cnblogs.com/bomo/archive/2013/03/16/2962430.html
.Net Framework 中提供了反射机制,可以再加载程序运行时,动态获取和加载程序集,并且可以获取到程序集的信息
在程序集中,包含模块(Module),模块包含类型,类型包含成员,提供反射,我们可以查看到一个程序集的路径,命名空间,类。我们还可以对其进行操作
可以对程序集的类进行实例化,掉用类中的方法等,就跟我们普通使用程序集一样
反射机制通常有下面一些用途
-
使用 Assembly 定义和加载程序集,加载在程序集清单中列出的模块,以及从此程序集中查找类型并创建该类型的实例。
-
使用 Module 发现以下信息:包含模块的程序集以及模块中的类等。 您还可以获取在模块上定义的所有全局方法或其他特定的非全局方法。
-
使用 ConstructorInfo 发现以下信息:构造函数的名称、参数、访问修饰符(如 public 或 private)和实现详细信息(如 abstract 或 virtual)等。 使用 Type 的 GetConstructors 或 GetConstructor 方法来调用特定的构造函数。
-
使用 MethodInfo 发现以下信息:方法的名称、返回类型、参数、访问修饰符(如 public 或 private)和实现详细信息(如 abstract 或 virtual)等。 使用 Type 的 GetMethods 或 GetMethod 方法来调用特定的方法。
-
使用 FieldInfo 发现以下信息:字段的名称、访问修饰符(如 public 或 private)和实现详细信息(如static)等;并获取或设置字段值。
-
使用 EventInfo 发现以下信息:事件的名称、事件处理程序数据类型、自定义特性、声明类型和反射类型等;并添加或移除事件处理程序。
-
使用 PropertyInfo 发现以下信息:属性的名称、数据类型、声明类型、反射类型和只读或可写状态等;并获取或设置属性值。
-
使用 ParameterInfo 发现以下信息:参数的名称、数据类型、参数是输入参数还是输出参数,以及参数在方法签名中的位置等。
-
当您在一个应用程序域的仅反射上下文中工作时,请使用 CustomAttributeData 来发现有关自定义特性的信息。 通过使用 CustomAttributeData,您不必创建特性的实例就可以检查它们。
-
关于反射,MSDN上有很详细的说明,这里不详细讲,下面简单说说反射的使用
http://msdn.microsoft.com/zh-cn/library/windowsphone/develop/f7ykdhsy.aspx
1、为了演示,我们自定义一个类库,自定义一个类
1 namespace 环环环环环 2 { 3 public class User 4 { 5 //字段 6 public string Field; 7 //属性 8 public string Name { get; set; } 9 10 //构造函数 11 public User() 12 { 13 this.Name = "无参构造"; 14 } 15 public User(string name) 16 { 17 this.Name = name; 18 } 19 20 //public函数 21 public void PublicShow() 22 { 23 Console.WriteLine(string.Format("反射调用一个public方法")); 24 } 25 //private函数 26 private void PrivateShow() 27 { 28 Console.WriteLine(string.Format("反射调用一个Private方法")); 29 } 30 //static函数 31 public static string StaticMethod() 32 { 33 return "反射调用了一个Static方法"; 34 } 35 //带参带返回值函数 36 public string GetString(string name) 37 { 38 return string.Format("大家好,我的名字是:{0}!", name); 39 } 40 41 //事件 42 public event EventHandler eventHandler; 43 //事件处理函数 44 public void DoEvent() 45 { 46 if(eventHandler != null) 47 eventHandler(null, EventArgs.Empty); 48 } 49 } 50 }
2、新建一个project,把上面编译好的库 环环环环环.dll 复制到Debug目录下
加载程序集
1 //获取程序集 2 Assembly assembly = Assembly.Load("环环环环环"); 3 Assembly assembly2 = Assembly.LoadFrom("环环环环环.dll"); 4 5 //从程序集中获取指定对象类型; 6 Type type = assembly.GetType("环环环环环.User"); 7 8 //使用Activator创建实例(无参数构造函数) 9 var user1 = Activator.CreateInstance(type); 10 //使用Activator创建实例(带参数构造函数) 11 var user2 = Activator.CreateInstance(type, "薄暮"); 12 13 //使用Assembly创建实例(无参数构造函数) 14 var user3 = assembly.CreateInstance("环环环环环.User"); 15 16 //反射无参构造函数 17 ConstructorInfo constructor1 = type.GetConstructor(new Type[] {}); 18 var user4 = constructor1.Invoke(new object[] { }); 19 20 //反射有参构造函数 21 ConstructorInfo constructor2 = type.GetConstructor(new Type[] { typeof(string) }); 22 var user5 = constructor2.Invoke(new object[] { "薄暮" }); 23 24 25 //调用public函数(无参数) 26 type.InvokeMember("PublicShow", 27 BindingFlags.InvokeMethod | BindingFlags.Public | BindingFlags.Instance, null, user1, 28 null); 29 30 //调用public函数(带参数) 31 string returnValue = 32 type.InvokeMember("GetString", 33 BindingFlags.InvokeMethod | BindingFlags.OptionalParamBinding, null, user1, 34 new object[] { "薄暮" }) as string; 35 36 // 调用静态方法 37 string returnValue2 = 38 type.InvokeMember("StaticMethod", BindingFlags.InvokeMethod | BindingFlags.Public | BindingFlags.Static, 39 null, null, new object[] {}) as string; 40 41 // 调用私有方法 . 42 type.InvokeMember("PrivateShow", 43 BindingFlags.InvokeMethod | BindingFlags.NonPublic | BindingFlags.Instance, null, user1, 44 new object[] {}); 45 46 //反射属性 47 var Name = 48 type.InvokeMember("Name", BindingFlags.GetProperty | BindingFlags.Public | BindingFlags.Instance, null, 49 user1, new object[] {}) as string; 50 51 //设置属性(设置Name属性为"新属性") 52 type.InvokeMember("Name", BindingFlags.SetProperty | BindingFlags.Public | BindingFlags.Instance, null, 53 user1, new object[] {"新属性"}); 54 55 //反射字段 56 string Field = 57 type.InvokeMember("Field", BindingFlags.GetField | BindingFlags.Public | BindingFlags.Instance, null, 58 user1, new object[] {}) as string; 59 60 //设置字段(设置Field字段为"新字段") 61 type.InvokeMember("Field", BindingFlags.SetField | BindingFlags.Public | BindingFlags.Instance, null, 62 user1, new object[] { "新字段" });
其实和java类似的,只是dotNet是通过dll的程序集的方式来实现