İngilizce dilinde oku

Aracılığıyla paylaş


Type.GetEvent Yöntem

Tanım

Geçerli tarafından belirtilen veya devralınan belirli bir olayı alır Type .

Aşırı Yüklemeler

GetEvent(String, BindingFlags)

Türetilmiş bir sınıfta geçersiz kılınırsa, EventInfo belirtilen bağlama kısıtlamalarını kullanarak belirtilen olayı temsil eden nesneyi döndürür.

GetEvent(String)

EventInfoBelirtilen ortak olayı temsil eden nesneyi döndürür.

GetEvent(String, BindingFlags)

Türetilmiş bir sınıfta geçersiz kılınırsa, EventInfo belirtilen bağlama kısıtlamalarını kullanarak belirtilen olayı temsil eden nesneyi döndürür.

C#
public abstract System.Reflection.EventInfo? GetEvent (string name, System.Reflection.BindingFlags bindingAttr);
C#
public abstract System.Reflection.EventInfo GetEvent (string name, System.Reflection.BindingFlags bindingAttr);

Parametreler

name
String

Geçerli tarafından belirtilen veya devralınan bir olayın adını içeren dize Type .

bindingAttr
BindingFlags

Aramanın nasıl yürütüldüğünü belirten numaralandırma değerlerinin bit düzeyinde birleşimi.

-veya- Default dönün null .

Döndürülenler

EventInfo

Bulunursa, geçerli tarafından tanımlanan veya devralınan belirtilen olayı temsil eden nesne Type ; Aksi durumda, null .

Uygulamalar

Özel durumlar

name, null değeridir.

Örnekler

Aşağıdaki kod örneği, GetEvent(String, BindingFlags) genel veya genel olmayan bir olay için bir tür aramak için yöntemini kullanır static ( Shared Visual Basic).

C#
using System;
using System.Reflection;
using System.Security;

class MyEventExample
{
    public static void Main()
    {
        try
        {

            // Creates a bitmask based on BindingFlags.
            BindingFlags myBindingFlags = BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic;
            Type myTypeBindingFlags = typeof(System.Windows.Forms.Button);
            EventInfo myEventBindingFlags = myTypeBindingFlags.GetEvent("Click", myBindingFlags);
            if(myEventBindingFlags != null)
            {
                Console.WriteLine("Looking for the Click event in the Button class with the specified BindingFlags.");
                Console.WriteLine(myEventBindingFlags.ToString());
            }
            else
            {
                Console.WriteLine("The Click event is not available with the Button class.");
            }
        }
        catch(SecurityException e)
        {
            Console.WriteLine("An exception occurred.");
            Console.WriteLine("Message :"+e.Message);
        }
        catch(ArgumentNullException e)
        {
            Console.WriteLine("An exception occurred.");
            Console.WriteLine("Message :"+e.Message);
        }
        catch(Exception e)
        {
            Console.WriteLine("The following exception was raised : {0}",e.Message);
        }
    }
}

Açıklamalar

BindingFlagsAramaya hangi olayların ekleneceğini tanımlamak için aşağıdaki filtre bayrakları kullanılabilir:

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

  • BindingFlags.PublicAramaya genel olayları eklemek için belirtin.

  • BindingFlags.NonPublicAramada genel olmayan olayları (yani özel, iç ve korumalı olayları) dahil etmek için belirtin.

  • BindingFlags.FlattenHierarchyHiyerarşinin dahil edileceğini public ve protected statik üyelerini belirtin; private devralınan sınıflarda statik üyeler dahil değildir.

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

  • BindingFlags.IgnoreCase durumunu yok saymak için name .

  • BindingFlags.DeclaredOnly yalnızca içinde belirtilen olayları aramak için, yalnızca Type devralınmış olayları değil.

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

Bir olay genel özellikli en az bir yöntem veya erişimci içeriyorsa, yansıma için genel sayılır. aksi takdirde olay özel olarak kabul edilir ve BindingFlags.NonPublic | | kullanmanız gerekir BindingFlags.Instance BindingFlags.Static (Visual Basic ' de değerleri birleştirerek Or ).

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

Geçerli, Type genel bir türün veya genel yöntemin tanımındaki bir tür parametresini temsil ediyorsa, bu yöntem sınıf kısıtlamasının olaylarını arar.

Ayrıca bkz.

Şunlara uygulanır

.NET 7 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
.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
.NET Standard 2.0, 2.1

GetEvent(String)

EventInfoBelirtilen ortak olayı temsil eden nesneyi döndürür.

C#
public System.Reflection.EventInfo? GetEvent (string name);
C#
public System.Reflection.EventInfo GetEvent (string name);

Parametreler

name
String

Geçerli tarafından belirtilen veya devralınan bir olayın adını içeren dize Type .

Döndürülenler

EventInfo

Bulunursa geçerli olan veya devralınan belirtilen genel olayı temsil eden nesne Type ; Aksi durumda, null .

Uygulamalar

Özel durumlar

name, null değeridir.

Örnekler

Aşağıdaki örnek bir nesnesi oluşturur EventInfo ve belirtilen olay için bir Button sınıfının olayını alır.

C#
using System;
using System.Reflection;
using System.Security;

class MyEventExample
{
    public static void Main()
    {
        try
        {

            Type myType = typeof(System.Windows.Forms.Button);
            EventInfo myEvent = myType.GetEvent("Click");
            if(myEvent != null)
            {
                Console.WriteLine("Looking for the Click event in the Button class.");
                Console.WriteLine(myEvent.ToString());
            }
            else
            {
                Console.WriteLine("The Click event is not available in the Button class.");
            }
        }
        catch(SecurityException e)
        {
            Console.WriteLine("An exception occurred.");
            Console.WriteLine("Message :"+e.Message);
        }
        catch(ArgumentNullException e)
        {
            Console.WriteLine("An exception occurred.");
            Console.WriteLine("Message :"+e.Message);
        }
        catch(Exception e)
        {
            Console.WriteLine("The following exception was raised : {0}",e.Message);
        }
    }
}

Açıklamalar

Bir olay genel özellikli en az bir yöntem veya erişimci içeriyorsa, yansıma için genel sayılır. aksi takdirde olay özel olarak kabul edilir ve BindingFlags.NonPublic | | kullanmanız gerekir BindingFlags.Instance BindingFlags.Static (Visual Basic ' de değerleri birleştirerek Or ).

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

Aşağıdaki tabloda, Get bir tür üzerinde yansıtılırken yöntemler tarafından bir temel sınıfın hangi üyelerinin döndürüldüğü 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.

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

Geçerli, Type genel bir türün veya genel yöntemin tanımındaki bir tür parametresini temsil ediyorsa, bu yöntem sınıf kısıtlamasının olaylarını arar.

Ayrıca bkz.

Şunlara uygulanır

.NET 7 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
.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
.NET Standard 2.0, 2.1