今天在论坛上看到一个帖子,反射一个方法,想来很简单,呵呵,结果一做,在要发射的方法里面有out参数;却是还是困扰了一会,问题解决了,还是共享出来好了。
构建一个类:
using System;
namespace WinFormTest
{
/// <summary>
/// TestReflection 的摘要说明。
/// </summary>
public class TestReflection
{
public TestReflection()
{
//
// TODO: 在此处添加构造函数逻辑
//
}
public int GetFlag()
{
return 1;
}
public int GetFlag(out int Result)
{
Result = 1;
return 2;
}
}
}
使用下面的方法来反射:
System.Type myType = typeof(TestReflection);
//反射生成改类型的对象实例
Object obj = myType.InvokeMember(null,BindingFlags.CreateInstance,null,null,null);
System.Int32 i=new System.Int32();
Object[] myArgs =new Object[] {i};
//MessageBox.Show(i.ToString());
//MessageBox.Show(((int)myArgs[0]).ToString());
//反射调用改带有out参数的GetFlag方法
myType.InvokeMember("GetFlag",BindingFlags.InvokeMethod,null,obj,myArgs);
//MessageBox.Show(i.ToString());
//MessageBox.Show(((int)myArgs[0]).ToString());
//MessageBox.Show(myType.InvokeMember("GetFlag",BindingFlags.InvokeMethod,null,obj,myArgs).ToString());
其实最重要的还是在参数处理那部分,myArgs[0]为反射方法返回的参数对象,把它转换为int型就为你想要得到的数据了。不能直接读取前面的i变量;这是由于这里存在一个值类型和引用类型的装箱操作的原因,反射返回的值应该是保存在传入的在托管堆上的object对象里。
最后的三个MessageBox.Show方法返回值,分别是0,1,2
我还是非常喜欢用Type.InvokeMember()方法来反射类型的成员,唯一不足就是不能反射事件成员。
用其他方法也能反射这样的方法成员,比如MethodInfo等等