İngilizce dilinde oku

Aracılığıyla paylaş


Type.GetMethod Yöntem

Tanım

Geçerli Typeöğesinin belirli bir yöntemini alır.

Aşırı Yüklemeler

GetMethod(String, Int32, BindingFlags, Binder, CallingConventions, Type[], ParameterModifier[])

Belirtilen bağlama kısıtlamalarını ve belirtilen çağırma kuralını kullanarak, parametreleri belirtilen genel parametre sayısı, bağımsız değişken türleri ve değiştiricilerle eşleşen belirtilen yöntemi arar.

GetMethod(String, BindingFlags, Binder, CallingConventions, Type[], ParameterModifier[])

Belirtilen bağlama kısıtlamalarını ve belirtilen çağırma kuralını kullanarak parametreleri belirtilen bağımsız değişken türleri ve değiştiricileriyle eşleşen belirtilen yöntemi arar.

GetMethod(String, Int32, BindingFlags, Binder, Type[], ParameterModifier[])

Belirtilen bağlama kısıtlamalarını kullanarak parametreleri belirtilen genel parametre sayısı, bağımsız değişken türleri ve değiştiricilerle eşleşen belirtilen yöntemi arar.

GetMethod(String, BindingFlags, Binder, Type[], ParameterModifier[])

Belirtilen bağlama kısıtlamalarını kullanarak, parametreleri belirtilen bağımsız değişken türleri ve değiştiricilerle eşleşen belirtilen yöntemi arar.

GetMethod(String, Int32, Type[], ParameterModifier[])

Parametreleri belirtilen genel parametre sayısı, bağımsız değişken türleri ve değiştiricilerle eşleşen belirtilen genel yöntemi arar.

GetMethod(String, Int32, BindingFlags, Type[])
GetMethod(String, BindingFlags)

Belirtilen bağlama kısıtlamalarını kullanarak belirtilen yöntemi arar.

GetMethod(String, BindingFlags, Type[])

Belirtilen bağlama kısıtlamalarını kullanarak parametreleri belirtilen bağımsız değişken türleriyle eşleşen belirtilen yöntemi arar.

GetMethod(String, Int32, Type[])

Parametreleri belirtilen genel parametre sayısı ve bağımsız değişken türleriyle eşleşen belirtilen genel yöntemi arar.

GetMethod(String, Type[])

Parametreleri belirtilen bağımsız değişken türleriyle eşleşen belirtilen ortak yöntemi arar.

GetMethod(String)

Belirtilen ada sahip ortak yöntemi arar.

GetMethod(String, Type[], ParameterModifier[])

Parametreleri belirtilen bağımsız değişken türleri ve değiştiricileriyle eşleşen belirtilen ortak yöntemi arar.

GetMethod(String, Int32, BindingFlags, Binder, CallingConventions, Type[], ParameterModifier[])

Kaynak:
Type.cs
Kaynak:
Type.cs
Kaynak:
Type.cs

Belirtilen bağlama kısıtlamalarını ve belirtilen çağırma kuralını kullanarak, parametreleri belirtilen genel parametre sayısı, bağımsız değişken türleri ve değiştiricilerle eşleşen belirtilen yöntemi arar.

C#
public System.Reflection.MethodInfo? GetMethod (string name, int genericParameterCount, System.Reflection.BindingFlags bindingAttr, System.Reflection.Binder? binder, System.Reflection.CallingConventions callConvention, Type[] types, System.Reflection.ParameterModifier[]? modifiers);
C#
public System.Reflection.MethodInfo GetMethod (string name, int genericParameterCount, System.Reflection.BindingFlags bindingAttr, System.Reflection.Binder binder, System.Reflection.CallingConventions callConvention, Type[] types, System.Reflection.ParameterModifier[] modifiers);

Parametreler

name
String

Alınacak ortak yöntemin adını içeren dize.

genericParameterCount
Int32

yönteminin genel tür parametrelerinin sayısı.

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ürecek null.

binder
Binder

Aşırı yüklenmiş yöntem seçimi, bağımsız değişken türlerinin uygulatılması ve yansıtma yoluyla bir üyenin çağrılması işlemlerini içerebilen; özellikler kümesini tanımlayan ve bağlama işlemine olanak veren bir nesne.

-veya-

kullanmak DefaultBinderiçin null başvuru (NothingVisual Basic'te).

callConvention
CallingConventions

Bağımsız değişkenlerin sırası ve düzeni, dönüş değerinin nasıl geçirildiğini, bağımsız değişkenler için hangi yazmaçların kullanıldığını ve yığının nasıl temizlendiğini belirten kural kümesini belirten nesne.

types
Type[]

Alınacak yöntemin Type parametrelerinin sayısını, sırasını ve türünü temsil eden bir nesne dizisi.

-veya-

Parametre almayan Type bir yöntem almak için boş bir nesne dizisi (alan tarafından EmptyTypes sağlandığı gibi).

modifiers
ParameterModifier[]

Dizideki ParameterModifier ilgili öğeyle types ilişkili öznitelikleri temsil eden bir nesne dizisi. Yalnızca COM birlikte çalışma aracılığıyla çağrılırken kullanılacak ve yalnızca başvuru tarafından geçirilen parametreler işlenir. Varsayılan bağlayıcı bu parametreyi işlemez.

Döndürülenler

Belirtilen genel parametre sayısı, bağımsız değişken türleri, değiştiriciler, bağlama kısıtlamaları ve varsa çağırma kuralıyla eşleşen yöntemi temsil eden bir nesne; aksi takdirde , null.

Özel durumlar

name, null değeridir.

-veya-

types, null değeridir.

-veya-

Dizideki öğelerden types biri şeklindedir null.

genericParameterCount negatiftir.

Şunlara uygulanır

.NET 9 ve diğer sürümler
Ürün Sürümler
.NET Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Standard 2.1

GetMethod(String, BindingFlags, Binder, CallingConventions, Type[], ParameterModifier[])

Kaynak:
Type.cs
Kaynak:
Type.cs
Kaynak:
Type.cs

Belirtilen bağlama kısıtlamalarını ve belirtilen çağırma kuralını kullanarak parametreleri belirtilen bağımsız değişken türleri ve değiştiricileriyle eşleşen belirtilen yöntemi arar.

C#
public System.Reflection.MethodInfo? GetMethod (string name, System.Reflection.BindingFlags bindingAttr, System.Reflection.Binder? binder, System.Reflection.CallingConventions callConvention, Type[] types, System.Reflection.ParameterModifier[]? modifiers);
C#
public System.Reflection.MethodInfo GetMethod (string name, System.Reflection.BindingFlags bindingAttr, System.Reflection.Binder binder, System.Reflection.CallingConventions callConvention, Type[] types, System.Reflection.ParameterModifier[] modifiers);

Parametreler

name
String

Alınacak yöntemin adını içeren dize.

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ürecek null.

binder
Binder

Aşırı yüklenmiş yöntem seçimi, bağımsız değişken türlerinin uygulatılması ve yansıtma yoluyla bir üyenin çağrılması işlemlerini içerebilen; özellikler kümesini tanımlayan ve bağlama işlemine olanak veren bir nesne.

-veya-

kullanmak DefaultBinderiçin null başvuru (NothingVisual Basic'te).

callConvention
CallingConventions

Bağımsız değişkenlerin sırası ve düzeni, dönüş değerinin nasıl geçirildiğini, bağımsız değişkenler için hangi yazmaçların kullanıldığını ve yığının nasıl temizlendiğini belirten kural kümesini belirten nesne.

types
Type[]

Alınacak yöntemin Type parametrelerinin sayısını, sırasını ve türünü temsil eden bir nesne dizisi.

-veya-

Parametre almayan Type bir yöntem almak için boş bir nesne dizisi (alan tarafından EmptyTypes sağlandığı gibi).

modifiers
ParameterModifier[]

Dizideki ParameterModifier ilgili öğeyle types ilişkili öznitelikleri temsil eden bir nesne dizisi. Yalnızca COM birlikte çalışma aracılığıyla çağrılırken kullanılacak ve yalnızca başvuru tarafından geçirilen parametreler işlenir. Varsayılan bağlayıcı bu parametreyi işlemez.

Döndürülenler

Bulunursa, belirtilen gereksinimlerle eşleşen yöntemi temsil eden bir nesne; aksi takdirde , null.

Uygulamalar

Özel durumlar

Belirtilen ada sahip ve belirtilen bağlama kısıtlamalarıyla eşleşen birden fazla yöntem bulundu.

name, null değeridir.

-veya-

types, null değeridir.

-veya-

içindeki types öğelerden biri şeklindedir null.

types çok boyutludur.

-veya-

modifiers çok boyutludur.

Örnekler

Aşağıdaki örnek bağlama kısıtlamalarını MethodA, çağırma kurallarını ve çeşitli bağımsız değişken türlerini belirten belirli aşırı yüklemelerini bulur.

Not

Visual C# 2005 örneği derleyici seçeneğini gerektirir /unsafe .

C#

using System;
using System.Reflection;

class Program3
{
    // Methods to get:

    public void MethodA(int i, int j) { }

    public void MethodA(int[] i) { }

    public unsafe void MethodA(int* i) { }

    public void MethodA(ref int r) {}

    // Method that takes an out parameter:
    public void MethodA(int i, out int o) { o = 100;}

  static void Main(string[] args)
  {
    MethodInfo mInfo;

    // Get MethodA(int i, int j)
    mInfo = typeof(Program).GetMethod("MethodA",
        BindingFlags.Public | BindingFlags.Instance,
        null,
        CallingConventions.Any,
        new Type[] { typeof(int), typeof(int) },
        null);
    Console.WriteLine("Found method: {0}", mInfo);

    // Get MethodA(int[] i)
    mInfo = typeof(Program).GetMethod("MethodA",
        BindingFlags.Public | BindingFlags.Instance,
        null,
        CallingConventions.Any,
        new Type[] { typeof(int[]) },
        null);
    Console.WriteLine("Found method: {0}", mInfo);

    // Get MethodA(int* i)
    mInfo = typeof(Program).GetMethod("MethodA",
        BindingFlags.Public | BindingFlags.Instance,
        null,
        CallingConventions.Any,
        new Type[] { typeof(int).MakePointerType() },
        null);
    Console.WriteLine("Found method: {0}", mInfo);

    // Get MethodA(ref int r)
    mInfo = typeof(Program).GetMethod("MethodA",
        BindingFlags.Public | BindingFlags.Instance,
        null,
        CallingConventions.Any,
        new Type[] { typeof(int).MakeByRefType() },
        null);
    Console.WriteLine("Found method: {0}", mInfo);

    // Get MethodA(int i, out int o)
    mInfo = typeof(Program).GetMethod("MethodA",
        BindingFlags.Public | BindingFlags.Instance,
        null,
        CallingConventions.Any,
        new Type[] { typeof(int), typeof(int).MakeByRefType() },
        null);
    Console.WriteLine("Found method: {0}", mInfo);
  }
}

Açıklamalar

Varsayılan bağlayıcı (modifiersparametresi) işlemese ParameterModifier de soyut sınıfını System.Reflection.Binder kullanarak işlemini modifiersgerçekleştiren özel bir bağlayıcı yazabilirsiniz. ParameterModifier yalnızca COM birlikte çalışma aracılığıyla çağrılırken kullanılır ve yalnızca başvuru tarafından geçirilen parametreler işlenir.

Aşağıdaki tabloda, bir türe yansıtılırken yöntemler tarafından GetXXX döndürülen temel sınıfın üyeleri gösterilmektedir.

Ü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.

Aşağıdaki BindingFlags filtre bayrakları, aramaya hangi yöntemlerin dahil edilebileceğini tanımlamak için kullanılabilir:

  • İade almak için veya BindingFlags.Static belirtmelisinizBindingFlags.Instance.

  • Genel yöntemleri aramaya dahil etmek için belirtin BindingFlags.Public .

  • Aramaya nonpublic yöntemlerini (özel, iç ve korumalı yöntemler) dahil etmek için belirtin BindingFlags.NonPublic .

  • Hiyerarşiye eklenecek public ve protected statik üyeleri belirtinBindingFlags.FlattenHierarchy; private devralınan sınıflardaki statik üyeler dahil değildir.

Aramanın çalışma şeklini değiştirmek için aşağıdaki BindingFlags değiştirici bayraklar kullanılabilir:

  • BindingFlags.IgnoreCase öğesinin büyük/küçük harf durumunu nameyoksaymak için.

  • BindingFlags.DeclaredOnly yalnızca üzerinde Typebildirilen yöntemleri aramak için yalnızca devralınan yöntemleri değil.

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

Not

Parametreleri, oluşturucular ve yöntemler ararken atlayamazsınız. Parametreleri yalnızca çağırırken atlayabilirsiniz.

Geçerli Type , yapılandırılmış bir genel türü temsil ederse, bu yöntem türü parametreleri uygun tür bağımsız değişkenleriyle değiştirilerek değerini döndürür MethodInfo .

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

Not

Genel yöntemler için, içindeki tür bağımsız değişkenlerini eklemeyin name. Örneğin, C# kodu GetMember("MyMethod<int>") türünde bir genel bağımsız değişkeni olan adlı bir yöntem yerine "MyMethod<int>" metin adına MyMethod sahip bir üyeyi intarar.

Ayrıca bkz.

Şunlara uygulanır

.NET 9 ve diğer sürümler
Ürün Sürümler
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1

GetMethod(String, Int32, BindingFlags, Binder, Type[], ParameterModifier[])

Kaynak:
Type.cs
Kaynak:
Type.cs
Kaynak:
Type.cs

Belirtilen bağlama kısıtlamalarını kullanarak parametreleri belirtilen genel parametre sayısı, bağımsız değişken türleri ve değiştiricilerle eşleşen belirtilen yöntemi arar.

C#
public System.Reflection.MethodInfo? GetMethod (string name, int genericParameterCount, System.Reflection.BindingFlags bindingAttr, System.Reflection.Binder? binder, Type[] types, System.Reflection.ParameterModifier[]? modifiers);
C#
public System.Reflection.MethodInfo GetMethod (string name, int genericParameterCount, System.Reflection.BindingFlags bindingAttr, System.Reflection.Binder binder, Type[] types, System.Reflection.ParameterModifier[] modifiers);

Parametreler

name
String

Alınacak ortak yöntemin adını içeren dize.

genericParameterCount
Int32

yönteminin genel tür parametrelerinin sayısı.

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ürecek null.

binder
Binder

Aşırı yüklenmiş yöntem seçimi, bağımsız değişken türlerinin uygulatılması ve yansıtma yoluyla bir üyenin çağrılması işlemlerini içerebilen; özellikler kümesini tanımlayan ve bağlama işlemine olanak veren bir nesne.

-veya-

kullanmak DefaultBinderiçin null başvuru (NothingVisual Basic'te).

types
Type[]

Alınacak yöntemin Type parametrelerinin sayısını, sırasını ve türünü temsil eden bir nesne dizisi.

-veya-

Parametre almayan Type bir yöntem almak için boş bir nesne dizisi (alan tarafından EmptyTypes sağlandığı gibi).

modifiers
ParameterModifier[]

Dizideki ParameterModifier ilgili öğeyle types ilişkili öznitelikleri temsil eden bir nesne dizisi. Yalnızca COM birlikte çalışma aracılığıyla çağrılırken kullanılacak ve yalnızca başvuru tarafından geçirilen parametreler işlenir. Varsayılan bağlayıcı bu parametreyi işlemez.

Döndürülenler

Varsa, belirtilen genel parametre sayısı, bağımsız değişken türleri, değiştiriciler ve bağlama kısıtlamalarıyla eşleşen yöntemi temsil eden bir nesne; aksi takdirde , null.

Özel durumlar

name, null değeridir.

-veya-

types, null değeridir.

-veya-

Dizideki öğelerden types biri şeklindedir null.

genericParameterCount negatiftir.

Şunlara uygulanır

.NET 9 ve diğer sürümler
Ürün Sürümler
.NET Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Standard 2.1

GetMethod(String, BindingFlags, Binder, Type[], ParameterModifier[])

Kaynak:
Type.cs
Kaynak:
Type.cs
Kaynak:
Type.cs

Belirtilen bağlama kısıtlamalarını kullanarak, parametreleri belirtilen bağımsız değişken türleri ve değiştiricilerle eşleşen belirtilen yöntemi arar.

C#
public System.Reflection.MethodInfo? GetMethod (string name, System.Reflection.BindingFlags bindingAttr, System.Reflection.Binder? binder, Type[] types, System.Reflection.ParameterModifier[]? modifiers);
C#
public System.Reflection.MethodInfo GetMethod (string name, System.Reflection.BindingFlags bindingAttr, System.Reflection.Binder binder, Type[] types, System.Reflection.ParameterModifier[] modifiers);

Parametreler

name
String

Alınacak yöntemin adını içeren dize.

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ürecek null.

binder
Binder

Aşırı yüklenmiş yöntem seçimi, bağımsız değişken türlerinin uygulatılması ve yansıtma yoluyla bir üyenin çağrılması işlemlerini içerebilen; özellikler kümesini tanımlayan ve bağlama işlemine olanak veren bir nesne.

-veya-

kullanmak DefaultBinderiçin null başvuru (NothingVisual Basic'te).

types
Type[]

Alınacak yöntemin Type parametrelerinin sayısını, sırasını ve türünü temsil eden bir nesne dizisi.

-veya-

Parametre almayan Type bir yöntem almak için boş bir nesne dizisi (alan tarafından EmptyTypes sağlandığı gibi).

modifiers
ParameterModifier[]

Dizideki ParameterModifier ilgili öğeyle types ilişkili öznitelikleri temsil eden bir nesne dizisi. Yalnızca COM birlikte çalışma aracılığıyla çağrılırken kullanılacak ve yalnızca başvuru tarafından geçirilen parametreler işlenir. Varsayılan bağlayıcı bu parametreyi işlemez.

Döndürülenler

Bulunursa, belirtilen gereksinimlerle eşleşen yöntemi temsil eden bir nesne; aksi takdirde , null.

Uygulamalar

Özel durumlar

Belirtilen ada sahip ve belirtilen bağlama kısıtlamalarıyla eşleşen birden fazla yöntem bulundu.

name, null değeridir.

-veya-

types, null değeridir.

-veya-

içindeki types öğelerden biri şeklindedir null.

types çok boyutludur.

-veya-

modifiers çok boyutludur.

Örnekler

Aşağıdaki örnek, bağlama kısıtlamalarını MethodAve çeşitli bağımsız değişken türlerini belirten belirli aşırı yüklemelerini bulur.

Not

Visual C# 2005 örneği derleyici seçeneğini gerektirir /unsafe .

C#

using System;
using System.Reflection;

class Program5
{
    // Methods to get:

    public void MethodA(int i, int j) { }

    public void MethodA(int[] i) { }

    public unsafe void MethodA(int* i) { }

    public void MethodA(ref int r) {}

    // Method that takes an out parameter.
    public void MethodA(int i, out int o) { o = 100; }

  static void Main(string[] args)
  {
    MethodInfo mInfo;

    // Get MethodA(int i, int j)
    mInfo = typeof(Program).GetMethod("MethodA",
        BindingFlags.Public | BindingFlags.Instance,
        null,
        new Type[] { typeof(int), typeof(int) },
        null);
    Console.WriteLine("Found method: {0}", mInfo);

    // Get MethodA(int[] i)
    mInfo = typeof(Program).GetMethod("MethodA",
        BindingFlags.Public | BindingFlags.Instance,
        null,
        new Type[] { typeof(int[]) },
        null);
    Console.WriteLine("Found method: {0}", mInfo);

    // Get MethodA(int* i)
    mInfo = typeof(Program).GetMethod("MethodA",
        BindingFlags.Public | BindingFlags.Instance,
        null,
        new Type[] { typeof(int).MakePointerType() },
        null);
    Console.WriteLine("Found method: {0}", mInfo);

    // Get MethodA(ref int r)
    mInfo = typeof(Program).GetMethod("MethodA",
        BindingFlags.Public | BindingFlags.Instance,
        null,
        new Type[] { typeof(int).MakeByRefType() },
        null);
    Console.WriteLine("Found method: {0}", mInfo);

    // Get MethodA(int i, out int o)
    mInfo = typeof(Program).GetMethod("MethodA",
        BindingFlags.Public | BindingFlags.Instance,
        null,
        new Type[] { typeof(int), typeof(int).MakeByRefType() },
        null);
    Console.WriteLine("Found method: {0}", mInfo);
  }
}

Açıklamalar

Varsayılan bağlayıcı (modifiersparametresi) işlemese ParameterModifier de soyut sınıfını System.Reflection.Binder kullanarak işlemini modifiersgerçekleştiren özel bir bağlayıcı yazabilirsiniz. ParameterModifier yalnızca COM birlikte çalışma aracılığıyla çağrılırken kullanılır ve yalnızca başvuru tarafından geçirilen parametreler işlenir.

Aşağıdaki BindingFlags filtre bayrakları, aramaya hangi yöntemlerin dahil edilebileceğini tanımlamak için kullanılabilir:

  • İade almak için veya BindingFlags.Static belirtmelisinizBindingFlags.Instance.

  • Genel yöntemleri aramaya dahil etmek için belirtin BindingFlags.Public .

  • Aramaya nonpublic yöntemlerini (özel, iç ve korumalı yöntemler) dahil etmek için belirtin BindingFlags.NonPublic .

  • Hiyerarşiye eklenecek public ve protected statik üyeleri belirtinBindingFlags.FlattenHierarchy; private devralınan sınıflardaki statik üyeler dahil değildir.

Aramanın çalışma şeklini değiştirmek için aşağıdaki BindingFlags değiştirici bayraklar kullanılabilir:

  • BindingFlags.IgnoreCase öğesinin büyük/küçük harf durumunu nameyoksaymak için.

  • BindingFlags.DeclaredOnly yalnızca üzerinde Typebildirilen yöntemleri aramak için yalnızca devralınan yöntemleri değil.

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

Not

Parametreleri, oluşturucular ve yöntemler ararken atlayamazsınız. Parametreleri yalnızca çağırırken atlayabilirsiniz.

Geçerli Type , yapılandırılmış bir genel türü temsil ederse, bu yöntem türü parametreleri uygun tür bağımsız değişkenleriyle değiştirilerek değerini döndürür MethodInfo .

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

Not

Genel yöntemler için, içindeki tür bağımsız değişkenlerini eklemeyin name. Örneğin, C# kodu GetMember("MyMethod<int>") türünde bir genel bağımsız değişkeni olan adlı bir yöntem yerine "MyMethod<int>" metin adına MyMethod sahip bir üyeyi intarar.

Ayrıca bkz.

Şunlara uygulanır

.NET 9 ve diğer sürümler
Ürün Sürümler
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1

GetMethod(String, Int32, Type[], ParameterModifier[])

Kaynak:
Type.cs
Kaynak:
Type.cs
Kaynak:
Type.cs

Parametreleri belirtilen genel parametre sayısı, bağımsız değişken türleri ve değiştiricilerle eşleşen belirtilen ortak yöntemi arar.

C#
public System.Reflection.MethodInfo? GetMethod (string name, int genericParameterCount, Type[] types, System.Reflection.ParameterModifier[]? modifiers);
C#
public System.Reflection.MethodInfo GetMethod (string name, int genericParameterCount, Type[] types, System.Reflection.ParameterModifier[] modifiers);

Parametreler

name
String

Alınacak ortak yöntemin adını içeren dize.

genericParameterCount
Int32

yönteminin genel tür parametrelerinin sayısı.

types
Type[]

Alınacak yöntemin Type parametrelerinin sayısını, sırasını ve türünü temsil eden bir nesne dizisi.

-veya-

Parametre almayan Type bir yöntem almak için boş bir nesne dizisi (alan tarafından EmptyTypes sağlandığı gibi).

modifiers
ParameterModifier[]

Dizideki ParameterModifier ilgili öğeyle types ilişkili öznitelikleri temsil eden bir nesne dizisi. Yalnızca COM birlikte çalışma aracılığıyla çağrılırken kullanılacak ve yalnızca başvuru tarafından geçirilen parametreler işlenir. Varsayılan bağlayıcı bu parametreyi işlemez.

Döndürülenler

Varsa, belirtilen genel parametre sayısı, bağımsız değişken türleri ve değiştiricileri ile eşleşen genel yöntemi temsil eden bir nesne; aksi takdirde , null.

Özel durumlar

name, null değeridir.

-veya-

types, null değeridir.

-veya-

Dizideki öğelerden types biri olur null.

genericParameterCount negatiftir.

Şunlara uygulanır

.NET 9 ve diğer sürümler
Ürün Sürümler
.NET Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Standard 2.1

GetMethod(String, Int32, BindingFlags, Type[])

Kaynak:
Type.cs
C#
public System.Reflection.MethodInfo? GetMethod (string name, int genericParameterCount, System.Reflection.BindingFlags bindingAttr, Type[] types);

Parametreler

name
String
genericParameterCount
Int32
bindingAttr
BindingFlags
types
Type[]

Döndürülenler

Şunlara uygulanır

.NET 9
Ürün Sürümler
.NET 9

GetMethod(String, BindingFlags)

Kaynak:
Type.cs
Kaynak:
Type.cs
Kaynak:
Type.cs

Belirtilen bağlama kısıtlamalarını kullanarak belirtilen yöntemi arar.

C#
public System.Reflection.MethodInfo? GetMethod (string name, System.Reflection.BindingFlags bindingAttr);
C#
public System.Reflection.MethodInfo GetMethod (string name, System.Reflection.BindingFlags bindingAttr);

Parametreler

name
String

Alınacak yöntemin adını içeren dize.

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 nulliçin .

Döndürülenler

Bulunursa, belirtilen gereksinimlerle eşleşen yöntemi temsil eden bir nesne; aksi takdirde , null.

Uygulamalar

Özel durumlar

Belirtilen ada sahip ve belirtilen bağlama kısıtlamalarıyla eşleşen birden fazla yöntem bulundu.

name, null değeridir.

Örnekler

Aşağıdaki örnek, belirtilen bağlama bayraklarıyla eşleşen yöntemi alır.

C#
using System;
using System.Reflection;

class Program2
{
    // Method to get:
    public void MethodA() { }

    static void Main(string[] args)
    {
        // Get MethodA()
        MethodInfo mInfo = typeof(Program).GetMethod("MethodA",
            BindingFlags.Public | BindingFlags.Instance);
        Console.WriteLine("Found method: {0}", mInfo);
    }
}

Açıklamalar

Aramaya hangi yöntemlerin dahil edilebileceğini tanımlamak için aşağıdaki BindingFlags filtre bayrakları kullanılabilir:

Aramanın çalışma şeklini değiştirmek için aşağıdaki BindingFlags değiştirici bayraklar kullanılabilir:

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

Bir yöntem aşırı yüklenmişse ve birden fazla aşırı yükleme bağımsız değişken tarafından bindingAttr belirtilen kısıtlamaları karşılıyorsa, yöntem bir AmbiguousMatchException özel durum oluşturur. Aşağıdaki örnekte, aşağıdaki nedenlerden dolayı bir özel durum oluşturulur:

  • türüTestClass, DisplayValue(String) yönteminin iki genel örnek aşırı yüklemesine DisplayValue sahiptir ve DisplayValue(String, Object[]).

  • türüTestClass, yönteminin Equals iki genel örnek aşırı yüklemesine sahiptir ve bunlardan biri : ve Equals(Object)'den ObjectEquals(TestClass) devralınır.

C#
using System;
using System.Reflection;

public class TestClass
{
    public void DisplayValue(String s)
    {
        Console.WriteLine(s);
    }

    public void DisplayValue(String s, params Object[] values)
    {
        Console.WriteLine(s, values);
    }

    public static bool Equals(TestClass t1, TestClass t2)
    {
        return Object.ReferenceEquals(t1, t2);
    }

    public bool Equals(TestClass t)
    {
        return Object.ReferenceEquals(this, t);
    }
}

public class Example1
{
    public static void Main()
    {
        Type t = typeof(TestClass);

        RetrieveMethod(t, "DisplayValue", BindingFlags.Public | BindingFlags.Instance);

        RetrieveMethod(t, "Equals", BindingFlags.Public | BindingFlags.Instance);

        RetrieveMethod(t, "Equals", BindingFlags.Public | BindingFlags.Instance | BindingFlags.DeclaredOnly);

        RetrieveMethod(t, "Equals", BindingFlags.Public | BindingFlags.Static);
    }

    private static void RetrieveMethod(Type t, String name, BindingFlags flags)
    {
        try
        {
            MethodInfo m = t.GetMethod(name, flags);
            if (m != null)
            {
                Console.Write("{0}.{1}(", t.Name, m.Name);
                ParameterInfo[] parms = m.GetParameters();
                for (int ctr = 0; ctr < parms.Length; ctr++)
                {
                    Console.Write(parms[ctr].ParameterType.Name);
                    if (ctr < parms.Length - 1)
                        Console.Write(", ");
                }
                Console.WriteLine(")");
            }
            else
            {
                Console.WriteLine("Method not found");
            }
        }
        catch (AmbiguousMatchException)
        {
            Console.WriteLine("The following duplicate matches were found:");
            MethodInfo[] methods = t.GetMethods(flags);
            foreach (var method in methods)
            {
                if (method.Name != name) continue;

                Console.Write("   {0}.{1}(", t.Name, method.Name);
                ParameterInfo[] parms = method.GetParameters();
                for (int ctr = 0; ctr < parms.Length; ctr++)
                {
                    Console.Write(parms[ctr].ParameterType.Name);
                    if (ctr < parms.Length - 1)
                        Console.Write(", ");
                }
                Console.WriteLine(")");
            }
        }
        Console.WriteLine();
    }
}
// The example displays the following output:
//       The following duplicate matches were found:
//          TestClass.DisplayValue(String)
//          TestClass.DisplayValue(String, Object[])
//       
//       The following duplicate matches were found:
//          TestClass.Equals(TestClass)
//          TestClass.Equals(Object)
//       
//       TestClass.Equals(TestClass)
//       
//       TestClass.Equals(TestClass, TestClass)

Belirli bir yöntemi almak için aşağıdakilerden birini yapabilirsiniz:

  • Bağlama kısıtlamalarını değiştirin. Önceki örnekte, türü tarafından bildirilen ve devralınmayan bir genel örnek Equals yöntemini alma girişimi başarıyla alır Equals(TestClass).

  • Yöntemin GetMethod parametrelerinin türlerini tanımlayan bir types parametre içeren yöntemin aşırı yüklemesini çağırın.

  • GetMethods(BindingFlags) Belirtilen bağlama özniteliklerine sahip bir türe ait tüm yöntemleri içeren bir dizi almak için yöntemini çağırın. Ardından, adlı nameyinelenen yöntemleri tanımlamak için yineleyebilirsiniz. Bu yaklaşım, özel durum için AmbiguousMatchException önceki örneğin işleyicisinde gösterilmiştir.

Geçerli Type , yapılandırılmış bir genel türü temsil ederse, bu yöntem türü parametreleri uygun tür bağımsız değişkenleriyle değiştirilerek değerini döndürür MethodInfo .

Geçerli Type , 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ının yöntemlerini veya sınıf kısıtlaması yoksa yöntemlerini Object arar.

Not

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

Ayrıca bkz.

Şunlara uygulanır

.NET 9 ve diğer sürümler
Ürün Sürümler
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1

GetMethod(String, BindingFlags, Type[])

Kaynak:
Type.cs
Kaynak:
Type.cs
Kaynak:
Type.cs

Belirtilen bağlama kısıtlamalarını kullanarak parametreleri belirtilen bağımsız değişken türleriyle eşleşen belirtilen yöntemi arar.

C#
public System.Reflection.MethodInfo? GetMethod (string name, System.Reflection.BindingFlags bindingAttr, Type[] types);

Parametreler

name
String

Alınacak yöntemin adını içeren dize.

bindingAttr
BindingFlags

Aramanın nasıl yürütüleceğini belirten numaralandırma değerlerinin bit düzeyinde birleşimi. -veya- Varsayılan olarak döndürülecek null.

types
Type[]

Alınacak yöntemin Type parametrelerinin sayısını, sırasını ve türünü temsil eden bir nesne dizisi. -veya- Parametre almayan Type bir yöntem almak için boş bir nesne dizisi (alan tarafından EmptyTypes sağlandığı gibi).

Döndürülenler

Bulunursa, belirtilen gereksinimlerle eşleşen yöntemi temsil eden bir nesne; aksi takdirde , null.

Şunlara uygulanır

.NET 9 ve diğer sürümler
Ürün Sürümler
.NET 6, 7, 8, 9

GetMethod(String, Int32, Type[])

Kaynak:
Type.cs
Kaynak:
Type.cs
Kaynak:
Type.cs

Parametreleri belirtilen genel parametre sayısı ve bağımsız değişken türleriyle eşleşen belirtilen ortak yöntemi arar.

C#
public System.Reflection.MethodInfo? GetMethod (string name, int genericParameterCount, Type[] types);
C#
public System.Reflection.MethodInfo GetMethod (string name, int genericParameterCount, Type[] types);

Parametreler

name
String

Alınacak ortak yöntemin adını içeren dize.

genericParameterCount
Int32

yönteminin genel tür parametrelerinin sayısı.

types
Type[]

Alınacak yöntemin Type parametrelerinin sayısını, sırasını ve türünü temsil eden bir nesne dizisi.

-veya-

Parametre almayan Type bir yöntem almak için boş bir nesne dizisi (alan tarafından EmptyTypes sağlandığı gibi).

Döndürülenler

Parametreleri belirtilen genel parametre sayısı ve bağımsız değişken türleriyle eşleşen ortak yöntemi temsil eden bir nesne; aksi takdirde , null.

Özel durumlar

name, null değeridir.

-veya-

types, null değeridir.

-veya-

Dizideki öğelerden types biri olur null.

genericParameterCount negatiftir.

Şunlara uygulanır

.NET 9 ve diğer sürümler
Ürün Sürümler
.NET Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Standard 2.1

GetMethod(String, Type[])

Kaynak:
Type.cs
Kaynak:
Type.cs
Kaynak:
Type.cs

Parametreleri belirtilen bağımsız değişken türleriyle eşleşen belirtilen ortak yöntemi arar.

C#
public System.Reflection.MethodInfo? GetMethod (string name, Type[] types);
C#
public System.Reflection.MethodInfo GetMethod (string name, Type[] types);

Parametreler

name
String

Alınacak ortak yöntemin adını içeren dize.

types
Type[]

Alınacak yöntemin Type parametrelerinin sayısını, sırasını ve türünü temsil eden bir nesne dizisi.

-veya-

Parametre almayan Type bir yöntem almak için boş bir nesne dizisi (alan tarafından EmptyTypes sağlandığı gibi).

Döndürülenler

Bulunursa parametreleri belirtilen bağımsız değişken türleriyle eşleşen ortak yöntemi temsil eden bir nesne; aksi takdirde , null.

Uygulamalar

Özel durumlar

Belirtilen ad ve belirtilen parametrelerle birden fazla yöntem bulundu.

name, null değeridir.

-veya-

types, null değeridir.

-veya-

içindeki types öğelerden biri de şeklindedir null.

types çok boyutludur.

Örnekler

Aşağıdaki örnek, çeşitli bağımsız değişken türlerini belirten belirli aşırı yüklemelerini MethodAbulur.

Not

Visual C# 2005 örneği derleyici seçeneğini gerektirir /unsafe .

C#

using System;
using System.Reflection;

class Program4
{
    // Methods to get:

    public void MethodA(int i, int j) { }

    public void MethodA(int[] i) { }

    public unsafe void MethodA(int* i) { }

    public void MethodA(ref int r) {}

    // Method that takes an out parameter:
    public void MethodA(int i, out int o) { o = 100;}

  static void Main(string[] args)
  {
    MethodInfo mInfo;

    // Get MethodA(int i, int i)
    mInfo = typeof(Program).GetMethod("MethodA",
        new Type[] { typeof(int), typeof(int) });
    Console.WriteLine("Found method: {0}", mInfo);

    // Get MethodA(int[] i)
    mInfo = typeof(Program).GetMethod("MethodA",
        new Type[] { typeof(int[]) });
    Console.WriteLine("Found method: {0}", mInfo);

    // Get MethodA(int* i)
    mInfo = typeof(Program).GetMethod("MethodA",
        new Type[] { typeof(int).MakePointerType() });
    Console.WriteLine("Found method: {0}", mInfo);

    // Get MethodA(ref int r)
    mInfo = typeof(Program).GetMethod("MethodA",
        new Type[] { typeof(int).MakeByRefType() });
    Console.WriteLine("Found method: {0}", mInfo);

    // Get MethodA(int i, out int o)
    mInfo = typeof(Program).GetMethod("MethodA",
        new Type[] { typeof(int), typeof(int).MakeByRefType() });
    Console.WriteLine("Found method: {0}", mInfo);
  }
}

Aşağıdaki örnek, genel olmayan bir türün Add (sınıfı), açık bir genel türün (ArrayListsınıfı) ve kapalı bir genel türün List<T> (List(Of String)türü) yöntemlerini temsil eden nesneleri alırMethodInfo.

C#
using System;
using System.Collections;
using System.Collections.Generic;
using System.Reflection;

public class Example
{
   public static void Main()
   {
      // Get a Type object that represents a non-generic type.
      GetAddMethod(typeof(ArrayList));

      var list = new List<String>();
      // Get a Type object that represents a constructed generic type.
      Type closed = list.GetType();
      GetAddMethod(closed);
      
      // Get a Type object that represents an open generic type.
      Type open = typeof(List<>);
      GetAddMethod(open);
   }

   private static void GetAddMethod(Type typ)
   {
      MethodInfo method;
      // Determine if this is a generic type.
      if (typ.IsGenericType) {
         // Is it an open generic type?
         if (typ.ContainsGenericParameters)
            method = typ.GetMethod("Add", typ.GetGenericArguments());
         // Get closed generic type arguments.
         else
            method = typ.GetMethod("Add", typ.GenericTypeArguments);
      }
      // This is not a generic type.
      else {
         method = typ.GetMethod("Add", new Type[] { typeof(Object) } );
      }

      // Test if an Add method was found.
      if (method == null) { 
         Console.WriteLine("No Add method found.");
         return;
      }   
      
      Type t = method.ReflectedType;
      Console.Write("{0}.{1}.{2}(", t.Namespace, t.Name, method.Name);
      ParameterInfo[] parms = method.GetParameters();
      for (int ctr = 0; ctr < parms.Length; ctr++)
         Console.Write("{0}{1}", parms[ctr].ParameterType.Name, 
                       ctr < parms.Length - 1 ? ", " : "");

      Console.WriteLine(")");
   }   
}
// The example displays the following output:
//       System.Collections.ArrayList.Add(Object)
//       System.Collections.Generic.List`1.Add(String)
//       System.Collections.Generic.List`1.Add(T)

Örnek, uygun MethodInfo nesneyi alan bir GetAddMethod yöntemi tanımlar. Açık bir genel türün bağımsız değişkenini types sağlamak için yöntemini çağırır Type.GetGenericArguments . Kapalı bir genel türün types bağımsız değişkenini sağlamak için özelliğinin Type.GenericTypeArguments değerini alır.

Açıklamalar

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

Not

Parametreleri, oluşturucular ve yöntemler ararken atlayamazsınız. Parametreleri yalnızca çağırırken atlayabilirsiniz.

Geçerli Type , yapılandırılmış bir genel türü temsil ederse, bu yöntem türü parametreleri uygun tür bağımsız değişkenleriyle değiştirilerek değerini döndürür MethodInfo .

Geçerli Type , 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ının yöntemlerini veya sınıf kısıtlaması yoksa yöntemlerini Object arar.

Not

name parametresi tür bağımsız değişkenlerini içeremez. Örneğin, C# kodu GetMethod("MyGenericMethod<int>") türünde tek bir genel bağımsız değişkeni intolan adlı bir yöntem yerine "MyGenericMethod<int>" metin adına MyGenericMethod sahip bir yöntem arar. Bunun yerine, dizideki types uygun parametreyle kullanınGetMethod("MyGenericMethod").

Ayrıca bkz.

Şunlara uygulanır

.NET 9 ve diğer sürümler
Ürün Sürümler
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1

GetMethod(String)

Kaynak:
Type.cs
Kaynak:
Type.cs
Kaynak:
Type.cs

Belirtilen ada sahip public yöntemini arar.

C#
public System.Reflection.MethodInfo? GetMethod (string name);
C#
public System.Reflection.MethodInfo GetMethod (string name);

Parametreler

name
String

Alınacak ortak yöntemin adını içeren dize.

Döndürülenler

Bulunursa belirtilen ada sahip ortak yöntemi temsil eden bir nesne; aksi takdirde , null.

Uygulamalar

Özel durumlar

Belirtilen ada sahip birden fazla yöntem bulundu.

name, null değeridir.

Örnekler

Aşağıdaki örnek adlı MethodAbir yöntem alır.

C#

using System;
using System.Reflection;

class Program
{

    // Method to get:
    public void MethodA() { }

    static void Main(string[] args)
    {

        // Get MethodA()
        MethodInfo mInfo = typeof(Program).GetMethod("MethodA");
        Console.WriteLine("Found method: {0}", mInfo);
    }
}

Açıklamalar

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

Bir yöntem aşırı yüklenmişse ve birden fazla genel yöntemi varsa, GetMethod(String) yöntem bir AmbiguousMatchException özel durum oluşturur. Aşağıdaki örnekte, yönteminin birden fazla genel aşırı yüklemesi Int32.ToString olduğundan bir özel durum oluşturulur. Öte yandan, yöntemi geçersiz kıldığından Person.ToStringObject.ToString ve bu nedenle aşırı yüklenmediğinden, GetMethod(String) yöntem nesnesini alabilir MethodInfo .

C#
using System;
using System.Reflection;

public class Person
{
    public String FirstName;
    public String LastName;

    public override String ToString()
    {
        return (FirstName + " " + LastName).Trim();
    }
}

public class Example2
{
    public static void Main()
    {
        Type t = typeof(Person);
        RetrieveMethod(t, "ToString");

        t = typeof(Int32);
        RetrieveMethod(t, "ToString");
    }

    private static void RetrieveMethod(Type t, String name)
    {
        try
        {
            MethodInfo m = t.GetMethod(name);
            if (m != null)
                Console.WriteLine("{0}.{1}: {2} method", m.ReflectedType.Name,
                                  m.Name, m.IsStatic ? "Static" : "Instance");
            else
                Console.WriteLine("{0}.ToString method not found", t.Name);
        }
        catch (AmbiguousMatchException)
        {
            Console.WriteLine("{0}.{1} has multiple public overloads.",
                              t.Name, name);
        }
    }
}
// The example displays the following output:
//       Person.ToString: Instance method
//       Int32.ToString has multiple public overloads.

Belirli bir yöntemi almak için aşağıdakilerden birini yapabilirsiniz:

  • yöntemini çağırın GetMethod(String, BindingFlags) ve yöntemini benzersiz olarak tanımlayan bir bindingAttr bağımsız değişken belirtin. Örneğin, bir tür statik ve örnek aşırı yüklemesine sahip olduğu için özel durum oluşursa, bağımsız değişkenini BindingFlags.InstanceOrBindingFlags.Instancebelirtebilirsiniz.bindingAttr

  • Yöntemin GetMethod parametrelerinin türlerini tanımlayan bir types parametre içeren yöntemin aşırı yüklemesini çağırın.

  • GetMethods() Bir türe ait tüm genel yöntemleri içeren bir dizi almak için yöntemini çağırın. Ardından, adlı nameyinelenen yöntemleri tanımlamak için yineleyebilirsiniz.

Geçerli Type , yapılandırılmış bir genel türü temsil ederse, bu yöntem türü parametreleri uygun tür bağımsız değişkenleriyle değiştirilerek değerini döndürür MethodInfo .

Geçerli Type , 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ının yöntemlerini veya sınıf kısıtlaması yoksa yöntemlerini Object arar.

Not

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

Ayrıca bkz.

Şunlara uygulanır

.NET 9 ve diğer sürümler
Ürün Sürümler
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1

GetMethod(String, Type[], ParameterModifier[])

Kaynak:
Type.cs
Kaynak:
Type.cs
Kaynak:
Type.cs

Parametreleri belirtilen bağımsız değişken türleri ve değiştiricileriyle eşleşen belirtilen ortak yöntemi arar.

C#
public System.Reflection.MethodInfo? GetMethod (string name, Type[] types, System.Reflection.ParameterModifier[]? modifiers);
C#
public System.Reflection.MethodInfo GetMethod (string name, Type[] types, System.Reflection.ParameterModifier[] modifiers);

Parametreler

name
String

Alınacak ortak yöntemin adını içeren dize.

types
Type[]

Alınacak yöntemin Type parametrelerinin sayısını, sırasını ve türünü temsil eden bir nesne dizisi.

-veya-

Parametre almayan Type bir yöntem almak için boş bir nesne dizisi (alan tarafından EmptyTypes sağlandığı gibi).

modifiers
ParameterModifier[]

Dizideki ParameterModifier ilgili öğeyle types ilişkili öznitelikleri temsil eden bir nesne dizisi. Yalnızca COM birlikte çalışma aracılığıyla çağrılırken kullanılacak ve yalnızca başvuru tarafından geçirilen parametreler işlenir. Varsayılan bağlayıcı bu parametreyi işlemez.

Döndürülenler

Bulunursa belirtilen gereksinimlerle eşleşen genel yöntemi temsil eden bir nesne; aksi takdirde , null.

Uygulamalar

Özel durumlar

Belirtilen ad ve belirtilen parametrelerle birden fazla yöntem bulundu.

name, null değeridir.

-veya-

types, null değeridir.

-veya-

içindeki types öğelerden biri de şeklindedir null.

types çok boyutludur.

-veya-

modifiers çok boyutludur.

Açıklamalar

Varsayılan bağlayıcı işlemese ParameterModifier de ( modifiers parametresi), soyut System.Reflection.Binder sınıfını kullanarak işlemini modifiersgerçekleştiren özel bir bağlayıcı yazabilirsiniz. ParameterModifier yalnızca COM birlikte çalışma aracılığıyla çağrılırken kullanılır ve yalnızca başvuru tarafından geçirilen parametreler işlenir.

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

Not

Parametreleri, oluşturucular ve yöntemler ararken atlayamazsınız. Parametreleri yalnızca çağırırken atlayabilirsiniz.

Geçerli Type , yapılandırılmış bir genel türü temsil ederse, bu yöntem türü parametreleri uygun tür bağımsız değişkenleriyle değiştirilerek değerini döndürür MethodInfo .

Geçerli Type , 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ının yöntemlerini veya sınıf kısıtlaması yoksa yöntemlerini Object arar.

Not

Genel yöntemler için içindeki tür bağımsız değişkenlerini eklemeyin name. Örneğin, C# kodu GetMethod("MyMethod<int>") türünde bir genel bağımsız değişkeni intolan adlı bir yöntem yerine "MyMethod<int>" metin adına MyMethod sahip bir üyeyi arar. Bunun yerine, dizideki types uygun parametreyle kullanınGetMethod("MyMethod").

Ayrıca bkz.

Şunlara uygulanır

.NET 9 ve diğer sürümler
Ürün Sürümler
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1