(C#)利用反射动态调用类成员

动态

(C#)利用反射动态调用类成员

使用反射动态调用类成员,需要Type类的一个方法:InvokeMember。对该方法的声明如下(摘抄于MSDN):

public object InvokeMember(

string name,

BindingFlags invokeAttr,

Binder binder,

object target,

object[] args

);

参数

name

String,它包含要调用的构造函数、方法、属性或字段成员的名称。

- 或 -

空字符串 (""),表示调用默认成员。

invokeAttr

一个位屏蔽,由一个或多个指定搜索执行方式的 BindingFlags 组成。访问可以是 BindingFlags 之一,如 Public、NonPublic、Private、InvokeMethod 和 GetField 等。不需要指定查找类型。如果省略查找类型,则将应用 BindingFlags.Public | BindingFlags.Instance。

binder

一个 Binder 对象,该对象定义一组属性并启用绑定,而绑定可能涉及选择重载方法、强制参数类型和通过反射调用成员。

- 或 -

若为空引用(Visual Basic 中为 Nothing),则使用 DefaultBinder。

target

要在其上调用指定成员的 Object。

args

包含传递给要调用的成员的参数的数组。

返回值

表示被调用成员的返回值的 Object。

备注:

下列 BindingFlags 筛选标志可用于定义包含在搜索中的成员:

为了获取返回值,必须指定 BindingFlags.Instance 或 BindingFlags.Static。

指定 BindingFlags.Public 可在搜索中包含公共成员。

指定 BindingFlags.NonPublic 可在搜索中包含非公共成员(即私有成员和受保护的成员)。

指定 BindingFlags.FlattenHierarchy 可包含层次结构上的静态成员。

下列 BindingFlags 修饰符标志可用于更改搜索的执行方式:

BindingFlags.IgnoreCase,表示忽略 name 的大小写。

BindingFlags.DeclaredOnly,仅搜索 Type 上声明的成员,而不搜索被简单继承的成员。

可以使用下列 BindingFlags 调用标志表示要对成员采取的操作:

CreateInstance,表示调用构造函数。忽略 name。对其他调用标志无效。

InvokeMethod,表示调用方法,而不调用构造函数或类型初始值设定项。对 SetField 或 SetProperty 无效。

GetField,表示获取字段值。对 SetField 无效。

SetField,表示设置字段值。对 GetField 无效。

GetProperty,表示获取属性。对 SetProperty 无效。

SetProperty 表示设置属性。对 GetProperty 无效。

下面通过例题对该方法进行简单应用(我一直以为,要让例题起到更容易理解文字的意义和作用,撰写的例题越简单越直观越好。)

using System;

using System.Reflection;

namespace ConsoleApplication9

{

class Love

{

public int field1;

private string _name;

public Love()

{

}

public string Name

{

get

{

return _name;

}

set

{

_name=value;

}

}

public int GetInt(int a)

{

return a;

}

public void Display(string str)

{

Console.WriteLine(str);

}

}

/// <summary>

/// Class1 的摘要说明。

/// </summary>

class Class1

{

/// <summary>

/// 应用程序的主入口点。

/// </summary>

[STAThread]

static void Main(string[] args)

{

//

// TODO: 在此处添加代码以启动应用程序

//

Love love = new Love();

Type type = love.GetType();

Object obj = type.InvokeMember(null,

BindingFlags.DeclaredOnly |

BindingFlags.Public | BindingFlags.NonPublic |

BindingFlags.Instance | BindingFlags.CreateInstance, null, null, args);

//调用没有返回值的方法

type.InvokeMember("Display",BindingFlags.InvokeMethod | BindingFlags.Public | BindingFlags.Instance , null , obj , new object[]{"aldfjdlf"});

//调用有返回值的方法

int i = (int)type.InvokeMember("GetInt",BindingFlags.InvokeMethod | BindingFlags.Public | BindingFlags.Instance,null,obj,new object[]{1});

Console.WriteLine(i);

//设置属性值

type.InvokeMember("Name",BindingFlags.SetProperty,null,obj,new string[]{"abc"});

//获取属性值

string str=(string)type.InvokeMember("Name",BindingFlags.GetProperty,null,obj,null);

Console.WriteLine(str);

//设置字段值

type.InvokeMember("field1",BindingFlags.SetField,null,obj,new object[]{444});

//获取字段值

int f=(int)type.InvokeMember("field1",BindingFlags.GetField,null,obj,null);

Console.WriteLine(f);

Console.ReadLine();

}

}

}

时间: 2024-12-09 21:43:51

(C#)利用反射动态调用类成员的相关文章

利用反射动态调用类成员

动态 (C#)利用反射动态调用类成员 使用反射动态调用类成员,需要Type类的一个方法:InvokeMember.对该方法的声明如下(摘抄于MSDN): public object InvokeMember( string name, BindingFlags invokeAttr, Binder binder, object target, object[] args ); 参数 name String,它包含要调用的构造函数.方法.属性或字段成员的名称. - 或 - 空字符串 (""

利用java反射机制调用类的私有方法(推荐)_java

试想一下,如果你可以轻易地调用一个类的私有方法,那么是不是说你的封装都失效了?最近在看java的反射机制,发现居然可以利用java的反射机制去调用其他类的私有方法,至于这能干什么,那就见人见智了.. 我写的一段简易实例代码如下: import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; /** * @author thomaslwq * @version 创建时间:Sep 4, 201

[转载]利用反射动态创建对象

利用反射动态创建对象 (转自张逸的blog) 前两天我发了一篇文章<通过反射动态实例化对象中出现的一个奇怪问题>,对反射中的某些问题疑惑不解.通过这几天不断查看MSDN,上网查询,现在终于解决了该问题. 在VS.Net中,有很多种方法动态调用对象的构造函数.一是通过Activator类的CreateInstance()方法.这个方法我们在Remoting中也用过.它实际上是在本地或从远程创建对象类型,或获取对现有远程对象的引用.它的方法签名是:public static object Crea

java 反射 动态调用不同类的静态方法(推荐)_java

准备调用的类 package ss; public class Use { public static Integer demo( String s ){ System.err.println(s+"<<<<<<成功!"); Integer ss=1; return ss; } } 执行调用的类 public class Ceshi { public static void main(String[] args) { try { String cla

Java反射的高级应用,模拟开发环境IDE动态搜索类成员以及方法,。。。。。

/*  *这个类可以根据 给定的一个Class字节码文件获取类的所有信息  *  编写者:xiaowei   *  这个例子仅仅作为反射的练手  *  喜欢的朋友继续完善  *  只是获得了所有访问权限但是没哟觉得而每个成员的权限类型  *  */ import java.lang.reflect.*; public final class FindClass  {    private String fieldList ;  //成员列表    private String methodLis

C#利用反射简化给类字段赋值

 这个例子主要的思路是建立一个类和数据库查询语句的字段结构是一致的 然后利用反射,直接用数据字段名称进行拼凑,给类对象的字段进行赋值 1.类的定义 namespace CCB_Donet.ClassFolder { public class FieldRuleInfo { public string gStrFNo; public string gStrFName; public string gStrFLock; public string gStrFCaption; public strin

.NET简谈反射(动态调用)

我们继续C#基础知识的学习,这篇文章主要要讲的是我们C#程序员迈向高级C#程序员的关键性的一步. 有的朋友会说事实不是这样的,我不用反射就不能开发吗?当然可以,但是用与不用肯定是不一样的,任何复杂抽象的分层架构或者说是复杂的设计模式均是建立在这些基础之上的,比如我们要进行模块化.组件化开发,要严格的消除模块之间的耦合,要进行动态接口调用.这样的强大而灵活的系统开发,必须要用反射才行:任何技术都有它存在的价值和意义,只要我们把它用在合适的位置就能发挥出惊人的力量:能尽可能的减少我们编写的代码,更能

直接调用类成员函数地址

一.成员函数指针的用法 在C++中,成员函数的指针是个比较特殊的东西.对普通的函数指针来说,可以视为一个地址,在需要的时候可以任意转换并直接调用.但对成员函数来说,常规类型转换是通不过编译的,调用的时候也必须采用特殊的语法.C++专门为成员指针准备了三个运算符: "::*"用于指针的声明,而"->*"和".*"用来调用指针指向的函数.比如: class tt { public: void foo(int x){ printf("\

Java动态调用类中方法代码_java

在Java中,调用类的方法有两种方式:对于静态方法可以直接使用类名调用,对于非静态方法必须使用类的对象调用.反射机制提供了比较另类的调用方式,可以根据需要指定要调用的方法,而不必在编程时确定.调用的方法不仅限于public的,还可以是private的.编写程序,使用反射机制调用Math类的静态方法sin()和非静态方法equals(). 思路如下:使用Math.class.getDeclaredMethod("sin", Double.TYPE);访问指定的方法,其中"sin