Type.FindMembers(MemberTypes, BindingFlags, MemberFilter, Object) 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.
Belirtilen üye türündeki MemberInfo nesnelerin filtrelenmiş bir dizisini döndürür.
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);
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()
Parametreler
- memberType
- MemberTypes
Aranacak üye türünü gösteren numaralandırma değerlerinin bit düzeyinde birleşimi.
- bindingAttr
- BindingFlags
Aramanın nasıl yürütüleceğini belirten numaralandırma değerlerinin bit düzeyinde birleşimi.
-veya-
Default öğesini döndürmek null
için .
- filter
- MemberFilter
Karşılaştırmaları yapan temsilci, şu anda incelenen filterCriteria
üye ve false
ile eşleşiyorsa geri dönertrue
.
- filterCriteria
- Object
Nesne dizisinde bir üyenin döndürülip döndürülmeyeceğini belirleyen arama ölçütleri MemberInfo
.
, MethodAttributes
ve MethodImplAttributes
alanlarıFieldAttributes
, bu sınıf tarafından sağlanan temsilciyle FilterAttribute
birlikte kullanılabilir.
Döndürülenler
Belirtilen üye türündeki MemberInfo nesnelerin filtrelenmiş dizisi.
-veya-
Geçerlinin Type filtre ölçütleri ile eşleşen türde memberType
üyeleri yoksa boş bir dizi.
Uygulamalar
Özel durumlar
filter
, null
değeridir.
Örnekler
Aşağıdaki örnek, belirtilen arama ölçütleri ile eşleşen bir sınıftaki tüm üyeleri bulur ve ardından eşleşen üyeleri görüntüler.
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();
}
/* The example produces the following output:
Result of FindMembers - Boolean ReferenceEquals(System.Object, System.Object)
*/
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;
}
}
/* The example produces the following output:
Result of FindMembers - Boolean ReferenceEquals(System.Object, System.Object)
*/
open System.Reflection
let delegateToSearchCriteria (objMemberInfo: MemberInfo) (objSearch: obj) =
// Compare the name of the member function with the filter criteria.
string objMemberInfo.Name = string objSearch
let objTest = obj ()
let objType = objTest.GetType ()
try
//Find all static or public methods in the Object class that match the specified name.
let arrayMemberInfo =
objType.FindMembers(MemberTypes.Method, BindingFlags.Public ||| BindingFlags.Static ||| BindingFlags.Instance, MemberFilter delegateToSearchCriteria, "ReferenceEquals")
for info in arrayMemberInfo do
printfn $"Result of FindMembers -\t{info}\n"
with e ->
printfn $"Exception : {e}"
(* The example produces the following output:
Result of FindMembers - Boolean ReferenceEquals(System.Object, System.Object)
*)
Imports System.Reflection
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
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
' The example produces the following output:
'
' Result of FindMembers - Boolean ReferenceEquals(System.Object, System.Object)
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önteminin FindMembers
üye bilgilerini başarıyla alması için, bağımsız değişkeninin bindingAttr
en az bir BindingFlags.Instance ve BindingFlags.Staticile birlikte en az bir ve BindingFlags.Publiciçermesi BindingFlags.NonPublic gerekir.
Aramaya hangi üyelerin dahil edilebileceğini tanımlamak için aşağıdaki BindingFlags filtre bayrakları kullanılabilir:
Örnek üyelerini aramaya dahil etmek için belirtin
BindingFlags.Instance
.Aramaya statik üyeler eklemek için belirtin
BindingFlags.Static
.Genel üyeleri aramaya dahil etmek için belirtin
BindingFlags.Public
.Genel olmayan üyeleri (özel, iç ve korumalı üyeler) aramaya dahil etmek için belirtin
BindingFlags.NonPublic
.
Aramanın çalışma şeklini değiştirmek için aşağıdaki BindingFlags değiştirici bayraklar kullanılabilir:
-
BindingFlags.DeclaredOnly
yalnızca üzerinde Typebildirilen üyeleri aramak için, yalnızca devralınan üyeleri değil.
Daha fazla bilgi edinmek için bkz. System.Reflection.BindingFlags.
Bu yöntemi kullanarak sınıf başlatıcısını (statik oluşturucu) almak için belirtmelisiniz BindingFlags.Static | BindingFlags.NonPublic (BindingFlags.StaticOr
BindingFlags.NonPublic Visual Basic'te). Özelliğini kullanarak sınıf başlatıcısını TypeInitializer da alabilirsiniz.
Current Type , genel bir tür veya genel yöntemin tür parametresini temsil ederse, FindMembers sınıf kısıtlaması tarafından bildirilen tüm üyeleri ve tür parametresinin arabirim kısıtlamalarını işler.
filter
bağımsız değişkeni , türünün MemberFilterözel bir temsilcisi olabileceği gibi, önceden tanımlanmış aşağıdaki temsilcilerden biri de olabilir:
Type.FilterAttribute, değer olarak
filterCriteria
birFieldAttributes, MethodAttributesveya MethodImplAttributes bit maskesi kullanır.Type.FilterName, öğesine geçirilen dizeyle her üye adının büyük/küçük harfe duyarlı bir karşılaştırmasını
filterCriteria
gerçekleştirir.Type.FilterNameIgnoreCase, öğesine geçirilen
filterCriteria
dizeyle her üye adının büyük/küçük harfe duyarsız bir karşılaştırmasını gerçekleştirir.