C# Event

Event

An event can have many handlers. With the event handler syntax, we create a notification system. We attach additional methods without changing other parts of the code. This makes programs easier to maintain.

Methods

Example

First, this example shows the event keyword. It creates an original event. The .NET Framework has many existing events: these are covered elsewhere. The delegate keyword is used to specify the EventHandler type.

Next:The event keyword is used to create an instance of an event that can store methods in its invocation list.

Keywords
Based on:

.NET 4.5

Program that uses event handler: C#

using System;

public delegate void EventHandler();

class Program
{
    public static event EventHandler _show;

    static void Main()
    {
	// Add event handlers to Show event.
	_show += new EventHandler(Dog);
	_show += new EventHandler(Cat);
	_show += new EventHandler(Mouse);
	_show += new EventHandler(Mouse);

	// Invoke the event.
	_show.Invoke();
    }

    static void Cat()
    {
	Console.WriteLine("Cat");
    }

    static void Dog()
    {
	Console.WriteLine("Dog");
    }

    static void Mouse()
    {
	Console.WriteLine("Mouse");
    }
}

Output

Dog
Cat
Mouse
Mouse
Plus

Control flow begins in the Main entry point. The _show event has four method instances added to its invocation list with the plus "+=" operator. This has no relation to the arithmetic addition operator.

Next:In the invocation list of the _show event, we add four events: Dog, Cat and two instances of Mouse.

Finally:When the Invoke method is called, each of those method instances are called. The strings are printed to the console.

Console.WriteLineExclamation mark

In this program, we use the static modifier on the event. This is not important. The example was designed this way to enable the event to be accessed directly in the static Main method: for simplicity.

Often:In program design, avoiding static instances is worthwhile. It can lead to many dependencies and excess complexity.

StaticStatic Method

Discussion

Concept

Events let you add methods to be triggered upon an external event. In your program design, you might add new event handlers dynamically for a specific action. Then at some point the Invoke method could be called.

Events reduce excessive changes. At the part of the code where you call Invoke to signify the event, you would not need to know all the different handlers that were added. This reduces the number of changes to the code.

Tip:The event handler notification system provides a way to isolate different parts of your program from excessive changes.

Uses

Window: Windows Forms

Events are used in many objects in the .NET Framework. The Windows Forms framework uses events for many controls. These events allow you to instantly act upon button clicks and key presses.

Windows Forms

Note:With threading, we use events on the BackgroundWorker type. We can monitor file system changes with FileSystemWatcher.

BackgroundWorkerFileSystemWatcher

Research

Note

Notifications are important. A class can provide notifications with an event. And then all other parts of the program can handle these events with event handlers. This is explained in the C# specification.

An event is a member that enables an object or class to provide notifications. Clients can attach executable code for events by supplying event handlers. Hejlsberg et al., p. 491

Specialized languages

Structure and Interpretation of Computer Programs

With events we can create a specialized language. A language is described with three principles. The first principle is use of primitive operations. The second is a way to combine elements. And the third is an ability to specify methods.

A powerful programming language is more than just a means for instructing a computer to perform tasks. The language also serves as a framework within which we organize our ideas about processes. Abelson & Sussman, p. 4

With events, the methods added to the event are the primitive functions. By adding event handler instances to an event, we achieve a means of combination. And the methods serve as a means of abstraction for a real-world model.

Caution:You can create an event with nearly any code construct. This material has little relation to the "event" C# keyword.

Summary

C# programming language

Typically, events are used on the built-in types developed for the .NET Framework itself. But for certain programs that need to attach many behaviors to different actions, custom events can provide an additional level of indirection.

Thus:With events we separate something that happens from the behaviors we want to occur. And this leads to higher-quality programs.


C#: Delegate