Type.GetMember Yöntem
Tanım
Önemli
Bazı bilgiler ürünün ön sürümüyle ilgilidir ve sürüm öncesinde önemli değişiklikler yapılmış olabilir. Burada verilen bilgilerle ilgili olarak Microsoft açık veya zımni hiçbir garanti vermez.
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
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. |
"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.
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.
Ö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.
- MemberInfo
- String
- DefaultBinder
- GetMembers()
- GetDefaultMembers()
- FindMembers(MemberTypes, BindingFlags, MemberFilter, Object)
Ş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
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
veyaBindingFlags.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 üyeleripublic
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 yoksaymakname
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.
- MemberInfo
- String
- BindingFlags
- DefaultBinder
- GetMembers()
- GetDefaultMembers()
- FindMembers(MemberTypes, BindingFlags, MemberFilter, Object)
Ş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
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
veyaBindingFlags.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 üyeleripublic
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 yoksaymakname
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.
- MemberInfo
- String
- BindingFlags
- DefaultBinder
- GetMembers()
- GetDefaultMembers()
- FindMembers(MemberTypes, BindingFlags, MemberFilter, Object)