首页 > 开发 > 综合 > 正文

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

2024-07-21 02:19:34
字体:
来源:转载
供稿:网友

商业源码热门下载www.html.org.cn

(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();

}

}

}




发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表