영어로 읽기

다음을 통해 공유


EventHandler 대리자

정의

이벤트 데이터가 없는 이벤트를 처리할 메서드를 나타냅니다.

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

매개 변수

sender
Object

이벤트 소스입니다.

e
EventArgs

이벤트 데이터가 포함되지 않은 개체입니다.

특성

예제

다음 예제에서는 대리자와 연결된 라는 ThresholdReached 이벤트를 보여 집니다 EventHandler . 대리자 EventHandler 에 할당된 메서드는 메서드에서 OnThresholdReached 호출됩니다.

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; }
    }
}

설명

.NET Framework 이벤트 모델은 이벤트를 처리기와 연결하는 이벤트 대리자가 있는 것을 기반으로 합니다. 이벤트를 발생하려면 다음 두 요소가 필요합니다.

  • 이벤트에 대한 응답을 제공하는 메서드를 식별하는 대리자입니다.

  • 필요에 따라 이벤트가 데이터를 제공하는 경우 이벤트 데이터를 보유하는 클래스입니다.

대리자는 시그니처, 즉 메서드의 반환 값 형식 및 매개 변수 목록 형식을 정의하는 형식입니다. 대리자 형식을 사용하여 대리자와 동일한 서명을 가진 메서드를 참조할 수 있는 변수를 선언할 수 있습니다.

이벤트 처리기 대리자의 표준 서명은 값을 반환하지 않는 메서드를 정의합니다. 이 메서드의 첫 번째 매개 변수는 형식 Object 이며 이벤트를 발생시키는 instance 참조합니다. 두 번째 매개 변수는 형식 EventArgs 에서 파생되며 이벤트 데이터를 보유합니다. 이벤트가 이벤트 데이터를 생성하지 않는 경우 두 번째 매개 변수는 단순히 필드 값입니다 EventArgs.Empty . 그렇지 않으면 두 번째 매개 변수는 에서 EventArgs 파생된 형식이며 이벤트 데이터를 보유하는 데 필요한 필드 또는 속성을 제공합니다.

EventHandler 대리자는 데이터를 생성하지 않는 이벤트에 대한 이벤트 처리기 메서드를 구체적으로 나타내는 미리 정의된 대리자입니다. 이벤트가 데이터를 생성하는 경우 제네릭 EventHandler<TEventArgs> 대리자 클래스를 사용해야 합니다.

이벤트를 처리할 메서드와 이벤트를 연결하려면 대리자의 instance 이벤트에 추가합니다. 대리자를 제거하지 않는 경우 이벤트가 발생할 때마다 이벤트 처리기가 호출됩니다.

이벤트 처리기 대리자에 대 한 자세한 내용은 참조 하세요. 이벤트 처리 및 발생합니다.

확장 메서드

GetMethodInfo(Delegate)

지정된 대리자가 나타내는 메서드를 나타내는 개체를 가져옵니다.

적용 대상

제품 버전
.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

추가 정보