用反射调用别人的.NET程序里的类和方法
2005-08-26 16:42
507 查看
如果想复用别人写的.NET程序但手上只有一个编译过的EXE,那么方法之一是用Reflection(反射)。下面是一些例子,初次上手的人可以参考。
先假设我们要复用的第三方应用程序EXE是由下面的代码编译成的:using System;
namespace MyNamespace
{
public class MyApp
{
public MyNestedObject myNestedObject=null;
public class MyNestedObject{
public string name;
}
public enum FourSeasonsEnum{
spring, summer, autumn, winter
}
public MyApp(){
}
public MyApp(MyNamespace.MyForm form){
}
public MyNestedObject Foo1(FourSeasonsEnum season){
return this.myNestedObject;
}
public string Foo2(){
return "";
}
static void Main(){
}
}
public class MyForm
{
public MyForm(){
}
}
}
以下是一些直接引用时常见的调用如何用Reflection来改写:
1. 用不含参数的构造函数生成对象
直接引用时,代码是MyNamespace.MyApp app=new MyNamespace.MyApp();用Reflection来调用的话就需要这么写(记得using System.Reflection)Assembly assem=Assembly.LoadFile(@"C:/Home/Workspace/MyNamespace/myapp.exe");
Type MyAppType=assem.GetType("MyNamespace.MyApp");
ConstructorInfo MyAppType_Constructor=MyAppType.GetConstructor(new Type[]{});
object app=MyAppType_Constructor.Invoke(new object[]{});
2. 用含参数的构造函数生成对象
直接引用时,代码是MyNamespace.MyApp app=new MyNamespace.MyApp(new MyNamespace.MyForm());用Reflection来调用的话就需要这么写Assembly assem=Assembly.LoadFile(@"C:/Home/Workspace/MyNamespace/myapp.exe");
Type MyAppType=assem.GetType("MyNamespace.MyApp");
Type MyFormType=assem.GetType("MyNamespace.MyForm");
ConstructorInfo MyAppType_Constructor=MyAppType.GetConstructor(new Type[]{MyFormType});
ConstructorInfo MyFormType_Constructor=MyFormType.GetConstructor(new Type[]{});
object form=MyFormType_Constructor.Invoke(new object[]{});
object app=MyAppType_Constructor.Invoke(new object[]{form});3. 调用对象的方法
直接引用时,代码是MyNamespace.MyApp app=new MyNamespace.MyApp();
string str=app.Foo2();用Reflection来调用的话就需要这么写Assembly assem=Assembly.LoadFile(@"C:/Home/Workspace/MyNamespace/myapp.exe");
Type MyAppType=assem.GetType("MyNamespace.MyApp");
ConstructorInfo MyAppType_Constructor=MyAppType.GetConstructor(new Type[]{});
object app=MyAppType_Constructor.Invoke(new object[]{});
object str=MyAppType.GetMethod("Foo2").Invoke(app,new object[]{});4. Set/Get成员变量
直接引用时,代码是MyNamespace.MyApp app=new MyNamespace.MyApp();
MyNamespace.MyApp.MyNestedObject obj=app.myNestedObject;
MyNamespace.MyApp.MyNestedObject obj2=new MyNamespace.MyApp.MyNestedObject();
app.myNestedObject =obj2;用Reflection来调用的话就需要这么写(注意,这里的MyNestedObject类是nested type,名字要用"MyNamespace.MyApp+MyNestedObject"而不是"MyNamespace.MyApp.MyNestedObject")Assembly assem=Assembly.LoadFile(@"C:/Home/Workspace/MyNamespace/myapp.exe");
Type MyAppType=assem.GetType("MyNamespace.MyApp");
ConstructorInfo MyAppType_Constructor=MyAppType.GetConstructor(new Type[]{});
object app=MyAppType_Constructor.Invoke(new object[]{});
Type MyNestedObjectType=assem.GetType("MyNamespace.MyApp+MyNestedObject");
FieldInfo MyNestedObjField=MyAppType.GetField("myNestedObject");
object obj=MyNestedObjField.GetValue(app);
ConstructorInfo MyNestedObjectType_Constructor=MyNestedObjectType.GetConstructor(new Type[]{});
object obj2=MyNestedObjectType_Constructor.Invoke(new object[]{});
MyNestedObjField.SetValue(app,obj2);5. 使用枚举类型
直接引用时,代码是MyNamespace.MyApp app=new MyNamespace.MyApp();
MyNamespace.MyApp.MyNestedObject obj=app.Foo1(MyNamespace.MyApp.FourSeasonsEnum.spring);用Reflection来调用的话就需要这么写Assembly assem=Assembly.LoadFile(@"C:/Home/Workspace/MyNamespace/myapp.exe");
Type MyAppType=assem.GetType("MyNamespace.MyApp");
ConstructorInfo MyAppType_Constructor=MyAppType.GetConstructor(new Type[]{});
object app=MyAppType_Constructor.Invoke(new object[]{});
Type FourSeasonsEnumType=assem.GetType("MyNamespace.MyApp+FourSeasonsEnum");
Array FourSeasonsEnumValues=Enum.GetValues(FourSeasonsEnumType);
object SpringValue=FourSeasonsEnumValues.GetValue(0);
object result=MyAppType.GetMethod("Foo1").Invoke(app,new object[]{SpringValue});---
最后,只要有可能,应该尽量不用Reflection,因为相比起直接调用,Reflection的性能相当差。
先假设我们要复用的第三方应用程序EXE是由下面的代码编译成的:using System;
namespace MyNamespace
{
public class MyApp
{
public MyNestedObject myNestedObject=null;
public class MyNestedObject{
public string name;
}
public enum FourSeasonsEnum{
spring, summer, autumn, winter
}
public MyApp(){
}
public MyApp(MyNamespace.MyForm form){
}
public MyNestedObject Foo1(FourSeasonsEnum season){
return this.myNestedObject;
}
public string Foo2(){
return "";
}
static void Main(){
}
}
public class MyForm
{
public MyForm(){
}
}
}
以下是一些直接引用时常见的调用如何用Reflection来改写:
1. 用不含参数的构造函数生成对象
直接引用时,代码是MyNamespace.MyApp app=new MyNamespace.MyApp();用Reflection来调用的话就需要这么写(记得using System.Reflection)Assembly assem=Assembly.LoadFile(@"C:/Home/Workspace/MyNamespace/myapp.exe");
Type MyAppType=assem.GetType("MyNamespace.MyApp");
ConstructorInfo MyAppType_Constructor=MyAppType.GetConstructor(new Type[]{});
object app=MyAppType_Constructor.Invoke(new object[]{});
2. 用含参数的构造函数生成对象
直接引用时,代码是MyNamespace.MyApp app=new MyNamespace.MyApp(new MyNamespace.MyForm());用Reflection来调用的话就需要这么写Assembly assem=Assembly.LoadFile(@"C:/Home/Workspace/MyNamespace/myapp.exe");
Type MyAppType=assem.GetType("MyNamespace.MyApp");
Type MyFormType=assem.GetType("MyNamespace.MyForm");
ConstructorInfo MyAppType_Constructor=MyAppType.GetConstructor(new Type[]{MyFormType});
ConstructorInfo MyFormType_Constructor=MyFormType.GetConstructor(new Type[]{});
object form=MyFormType_Constructor.Invoke(new object[]{});
object app=MyAppType_Constructor.Invoke(new object[]{form});3. 调用对象的方法
直接引用时,代码是MyNamespace.MyApp app=new MyNamespace.MyApp();
string str=app.Foo2();用Reflection来调用的话就需要这么写Assembly assem=Assembly.LoadFile(@"C:/Home/Workspace/MyNamespace/myapp.exe");
Type MyAppType=assem.GetType("MyNamespace.MyApp");
ConstructorInfo MyAppType_Constructor=MyAppType.GetConstructor(new Type[]{});
object app=MyAppType_Constructor.Invoke(new object[]{});
object str=MyAppType.GetMethod("Foo2").Invoke(app,new object[]{});4. Set/Get成员变量
直接引用时,代码是MyNamespace.MyApp app=new MyNamespace.MyApp();
MyNamespace.MyApp.MyNestedObject obj=app.myNestedObject;
MyNamespace.MyApp.MyNestedObject obj2=new MyNamespace.MyApp.MyNestedObject();
app.myNestedObject =obj2;用Reflection来调用的话就需要这么写(注意,这里的MyNestedObject类是nested type,名字要用"MyNamespace.MyApp+MyNestedObject"而不是"MyNamespace.MyApp.MyNestedObject")Assembly assem=Assembly.LoadFile(@"C:/Home/Workspace/MyNamespace/myapp.exe");
Type MyAppType=assem.GetType("MyNamespace.MyApp");
ConstructorInfo MyAppType_Constructor=MyAppType.GetConstructor(new Type[]{});
object app=MyAppType_Constructor.Invoke(new object[]{});
Type MyNestedObjectType=assem.GetType("MyNamespace.MyApp+MyNestedObject");
FieldInfo MyNestedObjField=MyAppType.GetField("myNestedObject");
object obj=MyNestedObjField.GetValue(app);
ConstructorInfo MyNestedObjectType_Constructor=MyNestedObjectType.GetConstructor(new Type[]{});
object obj2=MyNestedObjectType_Constructor.Invoke(new object[]{});
MyNestedObjField.SetValue(app,obj2);5. 使用枚举类型
直接引用时,代码是MyNamespace.MyApp app=new MyNamespace.MyApp();
MyNamespace.MyApp.MyNestedObject obj=app.Foo1(MyNamespace.MyApp.FourSeasonsEnum.spring);用Reflection来调用的话就需要这么写Assembly assem=Assembly.LoadFile(@"C:/Home/Workspace/MyNamespace/myapp.exe");
Type MyAppType=assem.GetType("MyNamespace.MyApp");
ConstructorInfo MyAppType_Constructor=MyAppType.GetConstructor(new Type[]{});
object app=MyAppType_Constructor.Invoke(new object[]{});
Type FourSeasonsEnumType=assem.GetType("MyNamespace.MyApp+FourSeasonsEnum");
Array FourSeasonsEnumValues=Enum.GetValues(FourSeasonsEnumType);
object SpringValue=FourSeasonsEnumValues.GetValue(0);
object result=MyAppType.GetMethod("Foo1").Invoke(app,new object[]{SpringValue});---
最后,只要有可能,应该尽量不用Reflection,因为相比起直接调用,Reflection的性能相当差。
相关文章推荐
- 用反射调用别人的.NET程序里的类和方法
- 用反射调用别人的.NET程序里的类和方法
- 用反射调用别人的.NET程序里的类和方法
- 用反射调用别人的.NET程序里的类和方法(转)
- .net 使用JQuery 调用Ashx 后面直接写方法名,通过反射找到对应的方法
- java 程序加载过程---3--类中申明同时申明类的静态对象 创建类的实例 访问类的静态变量 调用类的静态方法 使用反射方法 初始化类的子类对象 直接使用java.exe 调用某个类
- 在C++中反射调用.NET的方法(二)
- 一个小java反射程序,简单的调用方法。
- .net调用别人的http页面,返回结果,url中有中文的处理,get和post两种方法
- C# 如何利用反射来加载程序集,并调用程序集中有关类的方法
- 调用自定义的方法接口.ashx一般处理程序 借鉴了别人网页抓取的类
- 利用.net反射动态调用指定程序集的中的方法
- SQL存储过程(CLR存储过程)或函数中调用.NET程序集中的方法
- 代码演示 .NET 中普通方法的调用、反射调用、动态(Dynamic)调用的区别
- windows命令行下随时随地调用csc编译器的方法(解决dos下编译.net程序找不到CSC的问题)
- C#反射调用程序集类中方法
- 在C++中反射调用.NET的方法(一)
- 利用.net反射动态调用指定程序集的中的方法
- .NET 程序在 Windows XP 下调用 SHA512CryptoServiceProvider 方法报 PlatformNotSupportedException 异常
- 利用.net反射动态调用指定程序集的中的方法