Type.GetMember Yöntem

Tanım

Geçerli 'nin belirtilen üyelerini Type alır.

Aşırı Yüklemeler

GetMember(String)

Belirtilen adla ortak üyeleri arar.

GetMember(String, BindingFlags)

Belirtilen bağlama kısıtlamalarını kullanarak belirtilen üyeleri arar.

GetMember(String, MemberTypes, BindingFlags)

Belirtilen bağlama kısıtlamalarını kullanarak belirtilen üye türünün belirtilen üyelerini arar.

GetMember(String)

Belirtilen adla ortak üyeleri arar.

public:
 cli::array <System::Reflection::MemberInfo ^> ^ GetMember(System::String ^ name);
public:
 virtual cli::array <System::Reflection::MemberInfo ^> ^ GetMember(System::String ^ name);
public System.Reflection.MemberInfo[] GetMember (string name);
member this.GetMember : string -> System.Reflection.MemberInfo[]
abstract member GetMember : string -> System.Reflection.MemberInfo[]
override this.GetMember : string -> System.Reflection.MemberInfo[]
Public Function GetMember (name As String) As MemberInfo()

Parametreler

name
String

Elde etmek için ortak üyelerin adını içeren dize.

Döndürülenler

MemberInfo[]

Eğer bulunursa, belirtilen adla ortak üyeleri temsil eden nesneler dizisi; aksi MemberInfo takdirde boş bir dizi.

Uygulamalar

Özel durumlar

name, null değeridir.

Örnekler

Aşağıdaki örnek, C harfiyle başlayan String sınıfın tüm üyelerini görüntüler.

using namespace System;
using namespace System::Security;
using namespace System::Reflection;

// forward declarations:
void GetMemberInfo();
void GetPublicStaticMemberInfo();
void GetPublicInstanceMethodMemberInfo();
int main()
{
   try
   {
      GetMemberInfo();
      GetPublicStaticMemberInfo();
      GetPublicInstanceMethodMemberInfo();
   }
   catch ( ArgumentNullException^ e ) 
   {
      Console::WriteLine( "ArgumentNullException occurred." );
      Console::WriteLine( "Source: {0}", e->Source );
      Console::WriteLine( "Message: {0}", e->Message );
   }
   catch ( NotSupportedException^ e ) 
   {
      Console::WriteLine( "NotSupportedException occurred." );
      Console::WriteLine( "Source: {0}", e->Source );
      Console::WriteLine( "Message: {0}", e->Message );
   }
   catch ( SecurityException^ e ) 
   {
      Console::WriteLine( "SecurityException occurred." );
      Console::WriteLine( "Source: {0}", e->Source );
      Console::WriteLine( "Message: {0}", e->Message );
   }
   catch ( Exception^ e ) 
   {
      Console::WriteLine( "Exception occurred." );
      Console::WriteLine( "Source: {0}", e->Source );
      Console::WriteLine( "Message: {0}", e->Message );
   }

}

void GetMemberInfo()
{
   String^ myString = "GetMember_String";
   Type^ myType = myString->GetType();
   
   // Get the members for myString starting with the letter C.
   array<MemberInfo^>^myMembers = myType->GetMember( "C*" );
   if ( myMembers->Length > 0 )
   {
      Console::WriteLine( "\nThe 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 ] );
   }
   else
      Console::WriteLine( "No members match the search criteria." );
}

using System;
using System.Security;
using System.Reflection;

public class MyMemberSample
{
    public static void Main()
    {
        MyMemberSample myClass = new MyMemberSample();
        try
        {
            myClass.GetMemberInfo();
            myClass.GetPublicStaticMemberInfo();	
            myClass.GetPublicInstanceMethodMemberInfo();	
        }
        catch(ArgumentNullException e)
        {
            Console.WriteLine("ArgumentNullException occurred.");
            Console.WriteLine("Source: " + e.Source);
            Console.WriteLine("Message: " + e.Message);
        }
        catch(NotSupportedException e)
        {
            Console.WriteLine("NotSupportedException occurred.");
            Console.WriteLine("Source: " + e.Source);
            Console.WriteLine("Message: " + e.Message);
        }
        catch(SecurityException e)
        {
            Console.WriteLine("SecurityException occurred.");
            Console.WriteLine("Source: " + e.Source);
            Console.WriteLine("Message: " + e.Message);
        }
        catch(Exception e)
        {
            Console.WriteLine("Exception occurred.");
            Console.WriteLine("Source: " + e.Source);
            Console.WriteLine("Message: " + e.Message);
        }
    }

    public void GetMemberInfo()
    {
        String myString = "GetMember_String";

        Type myType = myString.GetType();
        // Get the members for myString starting with the letter C.
        MemberInfo[] myMembers = myType.GetMember("C*");
        if(myMembers.Length > 0)
        {
            Console.WriteLine("\nThe 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.");
        }
    }

Imports System.Security
Imports System.Reflection

Public Class MyMemberSample

    Public Shared Sub Main()
        Dim [myClass] As New MyMemberSample()
        Try
            [myClass].GetMemberInfo()
            [myClass].GetPublicStaticMemberInfo()
            [myClass].GetPublicInstanceMethodMemberInfo()
        Catch e As ArgumentNullException
            Console.WriteLine("ArgumentNullException occurred.")
            Console.WriteLine(("Source: " + e.Source))
            Console.WriteLine(("Message: " + e.Message))
        Catch e As NotSupportedException
            Console.WriteLine("NotSupportedException occurred.")
            Console.WriteLine(("Source: " + e.Source))
            Console.WriteLine(("Message: " + e.Message))
        Catch e As SecurityException
            Console.WriteLine("SecurityException occurred.")
            Console.WriteLine(("Source: " + e.Source))
            Console.WriteLine(("Message: " + e.Message))
        Catch e As Exception
            Console.WriteLine("Exception occurred.")
            Console.WriteLine(("Source: " + e.Source))
            Console.WriteLine(("Message: " + e.Message))
        End Try
    End Sub


    Public Sub GetMemberInfo()
        Dim myString As [String] = "GetMember_String"
        Dim myType As Type = myString.GetType()
        ' Get the members for myString starting with the letter C.
        Dim myMembers As MemberInfo() = myType.GetMember("C*")
        If myMembers.Length > 0 Then
            Console.WriteLine(ControlChars.Cr + "The member(s) starting with the letter C for type {0}:", myType)
            Dim index As Integer
            For index = 0 To myMembers.Length - 1
                Console.WriteLine("Member {0}: {1}", index + 1, myMembers(index).ToString())
            Next index
        Else
            Console.WriteLine("No members match the search criteria.")
        End If
    End Sub

Açıklamalar

araması name büyük/büyük/büyük harfe duyarlıdır. Arama genel statik ve genel örnek üyelerini içerir.

Üyeler; özellikleri, yöntemleri, alanları, olayları vb. içerir.

yöntemi, GetMember üyeleri alfabetik veya bildirim sırası gibi belirli bir sırada geri dönmez. Kodunuz üyelerin döndürüldüğü sıralamaya bağlı olmamalıdır, çünkü o sıralama değişir.

Bu yöntem aşırı yüklemesi sınıf başlatıcılarını (statik oluşturucu) bulamaz. Sınıf başlatıcılarını bulmak için, alan bir aşırı yükleme kullanın ve | BindingFlags BindingFlags.Static ( BindingFlags.NonPublic BindingFlags.Static Or BindingFlags.NonPublic Visual Basic). Sınıf başlatıcıyı özelliğini kullanarak da TypeInitializer eldeabilirsiniz.

Aşağıdaki tabloda, bir türe yansıtıldıklarında yöntemler tarafından Get döndürülen temel sınıfın üyelerini gösterir.

Üye Türü Statik Statik Olmayan
Oluşturucu Hayır Hayır
Alan Hayır Evet. Bir alan her zaman "ada ve imzaya göre gizle" özelliğindedir.
Olay Uygulanamaz Ortak tür sistemi kuralı, devralma işleminin özelliği uygulayan yöntemlerinkiyle aynı olmasıdır. Yansıma, özellikleri "ada ve imzaya göre gizle" şeklinde kullanır. Aşağıdaki 2. nota bakın.
Yöntem Hayır Evet. Bir yöntem (sanal ve sanal olmayan) "ada göre gizle" veya "ada ve imzaya göre gizle" özelliğinde olabilir.
İç İçe Tür Hayır Hayır
Özellik Uygulanamaz Ortak tür sistemi kuralı, devralma işleminin özelliği uygulayan yöntemlerinkiyle aynı olmasıdır. Yansıma, özellikleri "ada ve imzaya göre gizle" şeklinde kullanır. Aşağıdaki 2. nota bakın.
  1. "Ada ve imzaya göre gizle" özelliği, imzanın tüm parçalarını (özel değiştiriciler, dönüş türleri, parametre türleri, başlangıç/bitiş simgeleri ve yönetilmeyen çağrı kuralları dahil) dikkate alır. Bu ikili bir karşılaştırmadır.

  2. Yansıma için, özellikler ve olaylar "ada ve imzaya göre gizle" özelliğindedir. Bu temel sınıfta hem alma hem de ayarlama erişimcisine sahip bir özelliğiniz varsa, ancak türetilen sınıfın yalnızca bir alma erişimcisi varsa, türetilen sınıf özelliği temel sınıf özelliğini gizler ve siz de temel sınıfta ayarlayıcıya erişemezsiniz.

  3. Özel öznitelikler ortak tür sisteminin parçası değildir.

Geçerli, Type oluşturulmuş bir genel türü temsil ediyorsa, bu yöntem uygun tür bağımsız MemberInfo değişkenleriyle değiştirilmiş tür parametreleri ile döndürür.

Geçerli, genel bir türün veya genel yöntemin tanımında bir tür parametresini temsil ederse, bu yöntem sınıf kısıtlaması üyelerini veya sınıf kısıtlaması yoksa Type Object üyelerini arar.

Not

Genel yöntemler için, içinde tür bağımsız değişkenlerini dahil name değildir. Örneğin, C# kodu türünde bir genel bağımsız değişkene sahip adlı bir yöntem yerine " " metin adına sahip GetMember("MyMethod<int>") MyMethod<int> bir üye MyMethod int arar.

Ayrıca bkz.

Şunlara uygulanır

GetMember(String, BindingFlags)

Belirtilen bağlama kısıtlamalarını kullanarak belirtilen üyeleri arar.

public:
 virtual cli::array <System::Reflection::MemberInfo ^> ^ GetMember(System::String ^ name, System::Reflection::BindingFlags bindingAttr);
public virtual System.Reflection.MemberInfo[] GetMember (string name, System.Reflection.BindingFlags bindingAttr);
abstract member GetMember : string * System.Reflection.BindingFlags -> System.Reflection.MemberInfo[]
override this.GetMember : string * System.Reflection.BindingFlags -> System.Reflection.MemberInfo[]
Public Overridable Function GetMember (name As String, bindingAttr As BindingFlags) As MemberInfo()

Parametreler

name
String

Elde etmek istediğiniz üyelerin adını içeren dize.

bindingAttr
BindingFlags

Aramanın nasıl yürütül olduğunu belirten numaralama değerlerinin bit olarak bir birleşimi.

-veya- Default boş bir dizi döndürür.

Döndürülenler

MemberInfo[]

Eğer bulunursa, belirtilen adla ortak üyeleri temsil eden nesneler dizisi; aksi MemberInfo takdirde boş bir dizi.

Uygulamalar

Özel durumlar

name, null değeridir.

Örnekler

Aşağıdaki örnek, C harfiyle başlayan sınıfın myString tüm genel statik üyelerini görüntüler.

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
   array<MemberInfo^>^myMembers = myType->GetMember( "C*", static_cast<BindingFlags>(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 ] );
   }
   else
      Console::WriteLine( "No members match the search criteria." );
}
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.");
    }
}
Public Sub GetPublicStaticMemberInfo()
    Dim myString As [String] = "GetMember_String_BindingFlag"

    Dim myType As Type = myString.GetType()
    ' Get the public static members for the class myString starting with the letter C.
    Dim myMembers As MemberInfo() = myType.GetMember("C*", BindingFlags.Public Or BindingFlags.Static)

    If myMembers.Length > 0 Then
        Console.WriteLine(ControlChars.Cr + "The public static member(s) starting with the letter C for type {0}:", myType)
        Dim index As Integer
        For index = 0 To myMembers.Length - 1
            Console.WriteLine("Member {0}: {1}", index + 1, myMembers(index).ToString())
        Next index
    Else
        Console.WriteLine("No members match the search criteria.")
    End If
End Sub

Açıklamalar

Bu yöntem türetilmiş bir sınıf tarafından geçersiz kılınabilir.

Üyeler; özellikleri, yöntemleri, alanları, olayları vb. içerir.

yöntemi, GetMember üyeleri alfabetik veya bildirim sırası gibi belirli bir sırada geri dönmez. Kodunuz üyelerin döndürüldüğü sıralamaya bağlı olmamalıdır, çünkü o sıralama değişir.

Aramada BindingFlags hangi üyelerin dahil olacağını tanımlamak için aşağıdaki filtre bayrakları kullanılabilir:

  • Dönüş almak için BindingFlags.Instance veya BindingFlags.Static belirtmeniz gerekir.

  • Aramaya BindingFlags.Public ortak üyeleri dahil etmek için belirtin.

  • Genel olmayan üyelerin (özel, dahili ve BindingFlags.NonPublic korumalı üyeler) aramaya dahil etmek için belirtin.

  • Hiyerarşiye BindingFlags.FlattenHierarchy dahil edilecek üyeleri ve statik üyeleri public protected belirtin; private devralınan sınıflarda statik üyeler dahil değildir.

Aramanın BindingFlags nasıl çalıştığını değiştirmek için aşağıdaki değiştirici bayraklar kullanılabilir:

  • BindingFlags.IgnoreCase büyük/büyük/büyük/büyük harflerini yoksaymak name için.

  • BindingFlags.DeclaredOnly yalnızca üzerinde bildirilen üyeleri aramak Type için, yalnızca devralınan üyeleri aramaz.

Daha fazla bilgi edinmek için bkz. System.Reflection.BindingFlags.

Bu yöntem aşırı yüklemesi kullanarak sınıf başlatıcıyı (statik oluşturucu) almak için , için "statik oluşturucu" ve için | name BindingFlags.Static ( BindingFlags.NonPublic BindingFlags.Static Or BindingFlags.NonPublic Visual Basic) belirtmeniz bindingAttr gerekir. Sınıf başlatıcıyı özelliğini kullanarak da TypeInitializer eldeabilirsiniz.

Geçerli, Type oluşturulmuş bir genel türü temsil ediyorsa, bu yöntem uygun tür bağımsız MemberInfo değişkenleriyle değiştirilmiş tür parametreleri ile döndürür.

Geçerli, genel bir türün veya genel yöntemin tanımında bir tür parametresini temsil ederse, bu yöntem sınıf kısıtlaması üyelerini veya sınıf kısıtlaması yoksa Type Object üyelerini arar.

Not

Genel yöntemler için, içinde tür bağımsız değişkenlerini dahil name değildir. Örneğin, C# kodu türünde bir genel bağımsız değişkene sahip adlı bir yöntem yerine " " metin adına sahip GetMember("MyMethod<int>") MyMethod<int> bir üye MyMethod int arar.

Ayrıca bkz.

Şunlara uygulanır

GetMember(String, MemberTypes, BindingFlags)

Belirtilen bağlama kısıtlamalarını kullanarak belirtilen üye türünün belirtilen üyelerini arar.

public:
 virtual cli::array <System::Reflection::MemberInfo ^> ^ GetMember(System::String ^ name, System::Reflection::MemberTypes type, System::Reflection::BindingFlags bindingAttr);
public virtual System.Reflection.MemberInfo[] GetMember (string name, System.Reflection.MemberTypes type, System.Reflection.BindingFlags bindingAttr);
abstract member GetMember : string * System.Reflection.MemberTypes * System.Reflection.BindingFlags -> System.Reflection.MemberInfo[]
override this.GetMember : string * System.Reflection.MemberTypes * System.Reflection.BindingFlags -> System.Reflection.MemberInfo[]
Public Overridable Function GetMember (name As String, type As MemberTypes, bindingAttr As BindingFlags) As MemberInfo()

Parametreler

name
String

Elde etmek istediğiniz üyelerin adını içeren dize.

type
MemberTypes

Aranacak değer.

bindingAttr
BindingFlags

Aramanın nasıl yürütül olduğunu belirten numaralama değerlerinin bit olarak bir birleşimi.

-veya- Default boş bir dizi döndürür.

Döndürülenler

MemberInfo[]

Eğer bulunursa, belirtilen adla ortak üyeleri temsil eden nesneler dizisi; aksi MemberInfo takdirde boş bir dizi.

Uygulamalar

Özel durumlar

name, null değeridir.

Türetilmiş bir sınıfın bir uygulama sağlaması gerekir.

Örnekler

Aşağıdaki örnek, myString C harfiyle başlayan sınıfının tüm yöntemlerini görüntüler.

void GetPublicInstanceMethodMemberInfo()
{
   String^ myString = "GetMember_String_MemberType_BindingFlag";
   Type^ myType = myString->GetType();
   
   // Get the public instance methods for myString starting with the letter C.
   array<MemberInfo^>^myMembers = myType->GetMember( "C*", MemberTypes::Method, static_cast<BindingFlags>(BindingFlags::Public | BindingFlags::Instance) );
   if ( myMembers->Length > 0 )
   {
      Console::WriteLine( "\nThe public instance method(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 ] );
   }
   else
      Console::WriteLine( "No members match the search criteria." );
}
    public void GetPublicInstanceMethodMemberInfo()
    {
        String myString = "GetMember_String_MemberType_BindingFlag";
        Type myType = myString.GetType();
        // Get the public instance methods for myString starting with the letter C.
        MemberInfo[] myMembers = myType.GetMember("C*", MemberTypes.Method,
            BindingFlags.Public | BindingFlags.Instance);
        if(myMembers.Length > 0)
        {
            Console.WriteLine("\nThe public instance method(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.");
        }
    }
}
    Public Sub GetPublicInstanceMethodMemberInfo()
        Dim myString As [String] = "GetMember_String_MemberType_BindingFlag"

        Dim myType As Type = myString.GetType()
        ' Get the public instance methods for myString starting with the letter C.
        Dim myMembers As MemberInfo() = myType.GetMember("C*", MemberTypes.Method, BindingFlags.Public Or BindingFlags.Instance)
        If myMembers.Length > 0 Then
            Console.WriteLine(ControlChars.Cr + "The public instance method(s) starting with the letter C for type {0}:", myType)
            Dim index As Integer
            For index = 0 To myMembers.Length - 1
                Console.WriteLine("Member {0}: {1}", index + 1, myMembers(index).ToString())
            Next index
        Else
            Console.WriteLine("No members match the search criteria.")
        End If
    End Sub
End Class

Açıklamalar

Üyeler; özellikleri, yöntemleri, alanları, olayları vb. içerir.

yöntemi, GetMember üyeleri alfabetik veya bildirim sırası gibi belirli bir sırada geri dönmez. Kodunuz üyelerin döndürüldüğü sıralamaya bağlı olmamalıdır, çünkü o sıralama değişir.

Aramada BindingFlags hangi üyelerin dahil olacağını tanımlamak için aşağıdaki filtre bayrakları kullanılabilir:

  • Dönüş almak için BindingFlags.Instance veya BindingFlags.Static belirtmeniz gerekir.

  • Aramaya BindingFlags.Public ortak üyeleri dahil etmek için belirtin.

  • Genel olmayan üyelerin (özel, dahili ve BindingFlags.NonPublic korumalı üyeler) aramaya dahil etmek için belirtin.

  • Hiyerarşiye BindingFlags.FlattenHierarchy dahil edilecek üyeleri ve statik üyeleri public protected belirtin; private devralınan sınıflarda statik üyeler dahil değildir.

Aramanın BindingFlags nasıl çalıştığını değiştirmek için aşağıdaki değiştirici bayraklar kullanılabilir:

  • BindingFlags.IgnoreCase büyük/büyük/büyük/büyük harflerini yoksaymak name için.

  • BindingFlags.DeclaredOnly yalnızca üzerinde bildirilen üyeleri aramak Type için, yalnızca devralınan üyeleri aramaz.

Daha fazla bilgi edinmek için bkz. System.Reflection.BindingFlags.

Bu yöntem aşırı yüklemesi kullanarak sınıf başlatıcıyı (statik oluşturucu) almak için , ve için için "statik oluşturucu" ve için | name MemberTypes.Constructor ( type BindingFlags.Static BindingFlags.NonPublic BindingFlags.Static Or BindingFlags.NonPublic Visual Basic) belirtmeniz bindingAttr gerekir. Sınıf başlatıcıyı özelliğini kullanarak da TypeInitializer eldeabilirsiniz.

Geçerli, Type oluşturulmuş bir genel türü temsil ediyorsa, bu yöntem uygun tür bağımsız MemberInfo değişkenleriyle değiştirilmiş tür parametreleri ile döndürür.

Geçerli, genel bir türün veya genel yöntemin tanımında bir tür parametresini temsil ederse, bu yöntem sınıf kısıtlaması üyelerini veya sınıf kısıtlaması yoksa Type Object üyelerini arar.

Not

Genel yöntemler için, içinde tür bağımsız değişkenlerini dahil name değildir. Örneğin, C# kodu türünde bir genel bağımsız değişkene sahip adlı bir yöntem yerine " " metin adına sahip GetMember("MyMethod<int>") MyMethod<int> bir üye MyMethod int arar.

Ayrıca bkz.

Şunlara uygulanır