System.Type.GetDefaultMembers 方法

方法描述

搜索为设置了 DefaultMemberAttribute 的当前 Type 定义的成员。

语法定义(C# System.Type.GetDefaultMembers 方法 的用法)

public virtual MemberInfo[] GetDefaultMembers()

参数/返回值

参数值/返回值 参数类型/返回类型 参数描述/返回描述
返回值 System.Reflection.MemberInfo[] 表示当前 Type 的所有默认成员的 MemberInfo 对象数组。 - 或 - 如果当前 Type 没有默认成员,则为 MemberInfo 类型的空数组。

提示和注释

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

此方法可由派生类重写。

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

下表显示在某个类型上进行反射时,Get 方法返回的基类的成员。

成员类型

Static

非静态

构造函数

字段

是。 字段总是按名称和签名隐藏。

Event

不适用

常规类型系统规则是:该继承与实现属性的方法的继承相同。 反射将属性视为按名称和签名隐藏。 请参见下面的“注意 2”。

方法

是。 方法(虚方法和非虚方法)可按名称隐藏或按名称和签名隐藏。

嵌套类型

Property

不适用

常规类型系统规则是:该继承与实现属性的方法的继承相同。 反射将属性视为按名称和签名隐藏。 请参见下面的“注意 2”。

按名称和签名隐藏会考虑签名的所有部分,包括自定义修饰符、返回类型、参数类型、标记和非托管调用约定。 这是二进制比较。

对于反射,属性和事件按名称和签名隐藏。 如果基类中有同时带 get 访问器和 set 访问器的属性,但派生类中仅有 get 访问器,则派生类属性隐藏基类属性,并且您将无法访问基类的设置程序。

自定义特性不是常规类型系统的组成部分。

如果当前 Type 表示构造泛型类型,则此方法将返回 MemberInfo 对象,并且其类型形参替换为相应的类型实参。 例如,如果类 C 具有一个返回 T 的属性 P,调用 C 上的 GetDefaultMembers 在 C# 中将返回 int P(在 Visual Basic 中为 Property P As Integer)。

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

System.Type.GetDefaultMembers 方法例子

下面的示例获取 MyClass 的默认成员信息,并显示这些默认成员。

using System;
using System.Reflection;
using System.IO;

[DefaultMemberAttribute("Age")]   
public class MyClass
{
    public void Name(String s) {}
    public int Age
    {
        get
        {
            return 20;
        }
    }
    public static void Main()
    {
        try
        {
            Type  myType = typeof(MyClass);
            MemberInfo[] memberInfoArray = myType.GetDefaultMembers();
            if (memberInfoArray.Length > 0)
            {
                foreach(MemberInfo memberInfoObj in memberInfoArray)
                {
                    Console.WriteLine("The default member name is: " + memberInfoObj.ToString());
                }
            }
            else
            {
                Console.WriteLine("No default members are available."); 
            }
        }
        catch(InvalidOperationException e)
        {
            Console.WriteLine("InvalidOperationException: " + e.Message);
        }
        catch(IOException e)
        {
            Console.WriteLine("IOException: " + e.Message);
        }
        catch(Exception e)
        {
            Console.WriteLine("Exception: " + e.Message);
        }
    }
}

异常

异常 异常描述

命名空间

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 系统要求。