Przeczytaj w języku angielskim

Udostępnij za pośrednictwem


EventHandler Delegat

Definicja

Reprezentuje metodę, która będzie obsługiwać zdarzenie, które nie ma danych zdarzenia.

C#
public delegate void EventHandler(object sender, EventArgs e);
C#
public delegate void EventHandler(object? sender, EventArgs e);
C#
[System.Serializable]
public delegate void EventHandler(object sender, EventArgs e);
C#
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public delegate void EventHandler(object sender, EventArgs e);

Parametry

sender
Object

Źródło zdarzenia.

e
EventArgs

Obiekt, który nie zawiera żadnych danych zdarzenia.

Atrybuty

Przykłady

W poniższym przykładzie pokazano zdarzenie o nazwie ThresholdReached skojarzone z pełnomocnikiem EventHandler . Metoda przypisana do delegata EventHandler jest wywoływana w metodzie OnThresholdReached .

C#
using System;

namespace ConsoleApplication3
{
    public class Program3
    {
        public static void Main()
        {
            Counter c = new(new Random().Next(10));
            c.ThresholdReached += c_ThresholdReached;

            Console.WriteLine("press 'a' key to increase total");
            while (Console.ReadKey(true).KeyChar == 'a')
            {
                Console.WriteLine("adding one");
                c.Add(1);
            }
        }

        static void c_ThresholdReached(object? sender, ThresholdReachedEventArgs e)
        {
            Console.WriteLine("The threshold of {0} was reached at {1}.", e.Threshold,  e.TimeReached);
            Environment.Exit(0);
        }
    }

    class Counter
    {
        private readonly int _threshold;
        private int _total;

        public Counter(int passedThreshold)
        {
            _threshold = passedThreshold;
        }

        public void Add(int x)
        {
            _total += x;
            if (_total >= _threshold)
            {
                ThresholdReachedEventArgs args = new()
                {
                    Threshold = _threshold,
                    TimeReached = DateTime.Now
                };
                OnThresholdReached(args);
            }
        }

        protected virtual void OnThresholdReached(ThresholdReachedEventArgs e)
        {
            ThresholdReached?.Invoke(this, e);
        }

        public event EventHandler<ThresholdReachedEventArgs>? ThresholdReached;
    }

    public class ThresholdReachedEventArgs : EventArgs
    {
        public int Threshold { get; set; }
        public DateTime TimeReached { get; set; }
    }
}

Uwagi

Model zdarzeń w .NET Framework opiera się na delegowaniu zdarzeń, który łączy zdarzenie z jego procedurą obsługi. Aby zgłosić zdarzenie, potrzebne są dwa elementy:

  • Delegat, który identyfikuje metodę, która zapewnia odpowiedź na zdarzenie.

  • Opcjonalnie klasa, która przechowuje dane zdarzenia, jeśli zdarzenie dostarcza dane.

Delegat jest typem definiującym podpis, czyli zwracanym typem wartości i typem listy parametrów dla metody. Możesz użyć typu delegata, aby zadeklarować zmienną, która może odwoływać się do dowolnej metody z tym samym podpisem co delegat.

Standardowy podpis delegata procedury obsługi zdarzeń definiuje metodę, która nie zwraca wartości. Pierwszy parametr tej metody jest typu Object i odwołuje się do wystąpienia, które zgłasza zdarzenie. Drugi parametr pochodzi z typu EventArgs i przechowuje dane zdarzenia. Jeśli zdarzenie nie generuje danych zdarzenia, drugi parametr jest po prostu wartością EventArgs.Empty pola. W przeciwnym razie drugi parametr jest typem pochodzącym z EventArgs klasy i dostarcza wszystkie pola lub właściwości potrzebne do przechowywania danych zdarzenia.

Delegat EventHandler jest wstępnie zdefiniowanym delegatem, który konkretnie reprezentuje metodę obsługi zdarzeń dla zdarzenia, które nie generuje danych. Jeśli zdarzenie generuje dane, należy użyć ogólnej EventHandler<TEventArgs> klasy delegata.

Aby skojarzyć zdarzenie z metodą, która będzie obsługiwać zdarzenie, dodaj wystąpienie delegata do zdarzenia. Program obsługi zdarzeń jest wywoływany przy każdym wystąpieniu zdarzenia, o ile nie usunięto delegata.

Aby uzyskać więcej informacji na temat delegatów programu obsługi zdarzeń, zobacz Obsługa i podnoszenie zdarzeń.

Metody rozszerzania

GetMethodInfo(Delegate)

Pobiera obiekt reprezentujący metodę reprezentowaną przez określonego delegata.

Dotyczy

Produkt Wersje
.NET Core 1.0, Core 1.1, 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 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

Zobacz też