本文共 1173 字,大约阅读时间需要 3 分钟。
思路:在类型的type的对象上调用InvokeMember方法,传递要在其上调用方法的对象,并指定BindingFlags为InvokeMethod.根据方法签名,可能还需要传递参数。
示例(对普通方法和对静态方法的调用):
#region 动态调用方法——使用InvokeMember对一般方法的调用 //Type t = typeof(Calculator); //Calculator c = new Calculator(1, 2); //int result = (int)t.InvokeMember("Add", BindingFlags.InvokeMethod, null, c, null); //Console.WriteLine(result); #endregion
#region 动态调用方法——使用InvokeMember对静态含参数方法的调用 //object[] paramas = { 6, 9 }; //Type t = typeof(Calculator); //t.InvokeMember("Add", BindingFlags.InvokeMethod, null, t, paramas);//静态方法不是基于某个具体的类型实例,而是类型本身。方法参数还是以object数组传入的 #endregion
使用思路:先通过type对象的getMethod方法,获取想要调用的方法对象,也就是Methodinfo对象,然后在该对象上调用Invoke方法。根据方法签名,可能还需要传递参数。
#region 动态调用方法——使用MethodInfo.Invoke调用方法 Type t = typeof(Calculator); Calculator c = new Calculator(3, 4); MethodInfo mi = t.GetMethod("Add", BindingFlags.Instance | BindingFlags.Public); mi.Invoke(c, null); #endregion
其实有时候根据方法名称调用方法还是挺方便的,就是反射的带来的性能问题没有衡量过,都说性能不好,但是到底有多大影响,求解释?
转载地址:http://yoxwl.baihongyu.com/