System.Type.GetMember 方法 (String, BindingFlags)

方法描述

使用指定绑定约束搜索指定成员。

语法定义(C# System.Type.GetMember 方法 (String, BindingFlags) 的用法)

public virtual MemberInfo[] GetMember(
	string name,
	BindingFlags bindingAttr
)

参数/返回值

参数值/返回值 参数类型/返回类型 参数描述/返回描述
name System-String 包含要获取的成员的名称的字符串。
bindingAttr System-Reflection-BindingFlags 一个位屏蔽,由一个或多个指定搜索执行方式的 BindingFlags 组成。- 或 -零,返回空数组。
返回值 System.Reflection.MemberInfo[] 一个表示具有指定名称的公共成员的 MemberInfo 对象数组(如果找到的话);否则为空数组。

提示和注释

此方法可由派生类重写。

成员包括属性、方法、字段、事件等。

GetMember 方法不按特定的顺序(如字母顺序或声明顺序)返回成员。 您的代码一定不能依赖于成员的返回顺序,因为该顺序可以改变。

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

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

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

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

指定 BindingFlags.FlattenHierarchy 以便沿层次结构向上包括 public 和 protected 静态成员;不包括继承类中的 private 静态成员。

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

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

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

有关更多信息,请参见 System.Reflection.BindingFlags。

若要使用此方法重载获取类初始值设定项 (.cctor),必须为 name 和 BindingFlags.Static 指定“.cctor”。 | bindingAttr 的 BindingFlags.NonPublic(Visual Basic 中 BindingFlags.StaticOrBindingFlags.NonPublic)。 还可以使用 TypeInitializer 属性获取类初始值设定项。

如果当前 Type 表示构造泛型类型,则此方法将返回 MemberInfo,并且其类型形参替换为相应的类型实参。

如果当前 Type 表示泛型类型或泛型方法的定义中的类型参数,则此方法搜索类约束的成员或 Object 的成员(如果没有类约束的话)。

注意

对于泛型方法,请不要在 name 中包括此类型参数。 例如,C# 代码 GetMember("MyMethod") 搜索文本名称为“MyMethod”的成员,而不是搜索一个名为 MyMethod 的方法,该方法具有一个 int 类型的泛型参数。

System.Type.GetMember 方法 (String, BindingFlags)例子

下面的示例显示以字母“C”开头的 myString 类的所有公共静态成员。

public void GetPublicStaticMemberInfo()
{
    String myString = "GetMember_String_BindingFlag";
    Type myType = myString.GetType();
    // Get the public static members for the class myString starting with the letter C.
    MemberInfo[] myMembers = myType.GetMember("C*",
        BindingFlags.Public |BindingFlags.Static);
    if(myMembers.Length > 0)
    {
        Console.WriteLine("\nThe public static member(s) starting with the letter C for type {0}:", myType);
        for(int index=0; index < myMembers.Length; index++)
            Console.WriteLine("Member {0}: {1}", index + 1, myMembers[index].ToString());
    }
    else
        Console.WriteLine("No members match the search criteria.");    
}

异常

异常 异常描述
ArgumentNullException name 为 null。

命名空间

namespace: System

程序集: mscorlib(在 mscorlib.dll 中)

版本信息

.NET Framework 受以下版本支持:4、3.5、3.0、2.0、1.1、1.0 .NET Framework Client Profile 受以下版本支持:4、3.5 SP1 受以下版本支持:

适用平台

Windows 7, Windows Vista SP1 或更高版本, Windows XP SP3, Windows XP SP2 x64 Edition, Windows Server 2008(不支持服务器核心), Windows Server 2008 R2(支持 SP1 或更高版本的服务器核心), Windows Server 2003 SP2 .NET Framework 并不是对每个平台的所有版本都提供支持。有关支持的版本的列表,请参见.NET Framework 系统要求。