Type.FindMembers(MemberTypes, BindingFlags, MemberFilter, Object) Type.FindMembers(MemberTypes, BindingFlags, MemberFilter, Object) Type.FindMembers(MemberTypes, BindingFlags, MemberFilter, Object) Type.FindMembers(MemberTypes, BindingFlags, MemberFilter, Object) Method

定義

指定したメンバー型の MemberInfo オブジェクトの配列にフィルターを適用して返します。Returns a filtered array of MemberInfo objects of the specified member type.

public:
 virtual cli::array <System::Reflection::MemberInfo ^> ^ FindMembers(System::Reflection::MemberTypes memberType, System::Reflection::BindingFlags bindingAttr, System::Reflection::MemberFilter ^ filter, System::Object ^ filterCriteria);
public virtual System.Reflection.MemberInfo[] FindMembers (System.Reflection.MemberTypes memberType, System.Reflection.BindingFlags bindingAttr, System.Reflection.MemberFilter filter, object filterCriteria);
abstract member FindMembers : System.Reflection.MemberTypes * System.Reflection.BindingFlags * System.Reflection.MemberFilter * obj -> System.Reflection.MemberInfo[]
override this.FindMembers : System.Reflection.MemberTypes * System.Reflection.BindingFlags * System.Reflection.MemberFilter * obj -> System.Reflection.MemberInfo[]
Public Overridable Function FindMembers (memberType As MemberTypes, bindingAttr As BindingFlags, filter As MemberFilter, filterCriteria As Object) As MemberInfo()

パラメーター

memberType
MemberTypes MemberTypes MemberTypes MemberTypes

検索するメンバー型を示す、列挙値のビットごとの組み合わせ。A bitwise combination of the enumeration values that indicates the type of member to search for.

bindingAttr
BindingFlags BindingFlags BindingFlags BindingFlags

検索を実施する方法を指定する列挙値のビットごとの組み合わせ。A bitwise combination of the enumeration values that specify how the search is conducted.

または-or- null を返す場合は DefaultDefault to return null.

filter
MemberFilter MemberFilter MemberFilter MemberFilter

比較を実行して、現在調べているメンバーが true に一致する場合は filterCriteria を返し、それ以外の場合は false を返すデリゲート。The delegate that does the comparisons, returning true if the member currently being inspected matches the filterCriteria and false otherwise.

filterCriteria
Object Object Object Object

MemberInfo オブジェクトの配列でメンバーが返されたかどうかを判断する検索条件。The search criteria that determines whether a member is returned in the array of MemberInfo objects.

FieldAttributesMethodAttributesMethodImplAttributes の各フィールドは、このクラスで提供される FilterAttribute デリゲートと組み合わせて使用できます。The fields of FieldAttributes, MethodAttributes, and MethodImplAttributes can be used in conjunction with the FilterAttribute delegate supplied by this class.

戻り値

指定したメンバー型の MemberInfo オブジェクトのフィルター適用済みの配列。A filtered array of MemberInfo objects of the specified member type.

または-or- 現在の Type に、フィルター条件に一致する memberType 型のメンバーが存在しない場合は、空の配列。An empty array if the current Type does not have members of type memberType that match the filter criteria.

実装

例外

次の例では、指定した検索条件に一致したクラス内のすべてのメンバーを検索し、一致するメンバーを表示します。The following example finds all the members in a class that match the specified search criteria, and then displays the matched members.

using namespace System;
using namespace System::Reflection;
ref class MyFindMembersClass
{
public:
   static void Test()
   {
      Object^ objTest = gcnew Object;
      Type^ objType = objTest->GetType();
      array<MemberInfo^>^arrayMemberInfo;
      try
      {
         
         //Find all static or public methods in the Object class that match the specified name.
         arrayMemberInfo = objType->FindMembers( MemberTypes::Method, static_cast<BindingFlags>(BindingFlags::Public | BindingFlags::Static | BindingFlags::Instance), gcnew MemberFilter( DelegateToSearchCriteria ), "ReferenceEquals" );
         for ( int index = 0; index < arrayMemberInfo->Length; index++ )
            Console::WriteLine( "Result of FindMembers -\t {0}", String::Concat( arrayMemberInfo[ index ], "\n" ) );
      }
      catch ( Exception^ e ) 
      {
         Console::WriteLine( "Exception : {0}", e );
      }

   }

   static bool DelegateToSearchCriteria( MemberInfo^ objMemberInfo, Object^ objSearch )
   {
      
      // Compare the name of the member function with the filter criteria.
      if ( objMemberInfo->Name->Equals( objSearch->ToString() ) )
            return true;
      else
            return false;
   }

};

int main()
{
   MyFindMembersClass::Test();
}

using System;
using System.Reflection;

class MyFindMembersClass
{
    public static void Main()
    {
        Object objTest = new Object();
        Type objType = objTest.GetType ();
        MemberInfo[] arrayMemberInfo;
        try
        {
            //Find all static or public methods in the Object class that match the specified name.
            arrayMemberInfo = objType.FindMembers(MemberTypes.Method,
                BindingFlags.Public | BindingFlags.Static| BindingFlags.Instance,
                new MemberFilter(DelegateToSearchCriteria),
                "ReferenceEquals");

            for(int index=0;index < arrayMemberInfo.Length ;index++)
                Console.WriteLine ("Result of FindMembers -\t"+ arrayMemberInfo[index].ToString() +"\n");                 
        }
        catch (Exception e)
        {
            Console.WriteLine ("Exception : " + e.ToString() );            
        }           
    }
    public static bool DelegateToSearchCriteria(MemberInfo objMemberInfo, Object objSearch)
    {
        // Compare the name of the member function with the filter criteria.
        if(objMemberInfo.Name.ToString() == objSearch.ToString())
            return true;
        else 
            return false;
    }
}

Imports System
Imports System.Reflection
Imports Microsoft.VisualBasic

Class MyFindMembersClass

    Public Shared Sub Main()
        Dim objTest As New Object()
        Dim objType As Type = objTest.GetType()
        Dim arrayMemberInfo() As MemberInfo
        Try
            'Find all static or public methods in the Object 
            'class that match the specified name.
            arrayMemberInfo = objType.FindMembers(MemberTypes.Method, _
                              BindingFlags.Public Or BindingFlags.Static _
                              Or BindingFlags.Instance, _
                              New MemberFilter(AddressOf DelegateToSearchCriteria), _
                              "ReferenceEquals")

            Dim index As Integer
            For index = 0 To arrayMemberInfo.Length - 1
                Console.WriteLine("Result of FindMembers -" + ControlChars.Tab + _
                               arrayMemberInfo(index).ToString() + ControlChars.Cr)
            Next index
        Catch e As Exception
            Console.WriteLine("Exception : " + e.ToString())
        End Try
    End Sub 'Main

    Public Shared Function DelegateToSearchCriteria _
                            (ByVal objMemberInfo As MemberInfo, _
                             ByVal objSearch As Object) As Boolean
        ' Compare the name of the member function with the filter criteria.
        If objMemberInfo.Name.ToString() = objSearch.ToString() Then
            Return True
        Else
            Return False
        End If
    End Function 'DelegateToSearchCriteria 
End Class 'MyFindMembersClass

注釈

このメソッドは、派生クラスでオーバーライドできます。This method can be overridden by a derived class.

メンバーには、プロパティ、メソッド、フィールド、イベント、およびなどが含まれます。Members include properties, methods, fields, events, and so on.

FindMembersメンバーについてを正常に取得するメソッド、bindingAttr引数には、少なくとも 1 つ含める必要がありますBindingFlags.InstanceBindingFlags.Staticの少なくとも 1 つと共にBindingFlags.NonPublicBindingFlags.Publicします。For the FindMembers method to successfully retrieve member information, the bindingAttr argument must include at least one of BindingFlags.Instance and BindingFlags.Static, along with at least one of BindingFlags.NonPublic and BindingFlags.Public.

BindingFlagsフィルター フラグは、検索に含めるメンバーを定義するために使用できます。The following BindingFlags filter flags can be used to define which members to include in the search:

  • 指定BindingFlags.Instanceインスタンス メンバーを検索に含める。Specify BindingFlags.Instance to include instance members in the search.

  • 指定BindingFlags.Static検索に静的メンバーを含める。Specify BindingFlags.Static to include static members in the search.

  • 指定BindingFlags.Public検索にパブリック メンバーを含める。Specify BindingFlags.Public to include public members in the search.

  • 指定BindingFlags.NonPublic検索条件に非パブリック メンバー (つまり、プライベート、内部、および保護されたメンバー) を含める。Specify BindingFlags.NonPublic to include non-public members (that is, private, internal, and protected members) in the search.

BindingFlags修飾フラグは、検索の動作を変更するために使用できます。The following BindingFlags modifier flags can be used to change how the search works:

  • BindingFlags.DeclaredOnly 宣言されたメンバーのみを検索する、 Type、継承されたメンバーされません。BindingFlags.DeclaredOnly to search only the members declared on the Type, not members that were simply inherited.

詳細については、「System.Reflection.BindingFlags」を参照してください。See System.Reflection.BindingFlags for more information.

このメソッドを使用してクラス初期化子 (静的コンス トラクター) を取得することを指定する必要がありますBindingFlags.Static | BindingFlags.NonPublic (BindingFlags.Static Or BindingFlags.NonPublic Visual Basic で)。To get the class initializer (static constructor) using this method, you must specify BindingFlags.Static | BindingFlags.NonPublic (BindingFlags.StaticOrBindingFlags.NonPublic in Visual Basic). 使用して、クラス初期化子を取得することも、TypeInitializerプロパティ。You can also get the class initializer using the TypeInitializer property.

場合、現在Type、ジェネリック型またはジェネリック メソッドの型パラメーターを表してFindMembersクラスの制約と型パラメーターのインターフェイスの制約で宣言されたすべてのメンバーを処理します。If the current Type represents a type parameter of a generic type or generic method, FindMembers processes any members declared by the class constraint and the interface constraints of the type parameter.

filter引数は、カスタム型のデリゲートMemberFilter、か、次の定義済みのデリゲートのいずれかであることができます。The filter argument can be a custom delegate of type MemberFilter, or it can be one of the following predefined delegates:

適用対象

こちらもご覧ください