Delegate
Eintrag zuletzt aktualisiert am: 11.10.2011
deutsch: Delegaten (Funktionszeiger)
Delegaten (engl. Delegates) sind typsichere Zeiger auf Funktionen. Durch Delegaten kann der aufzurufende Code variabel gehalten werden. Sie kommen insbesondere zum Einsatz für die Ereignisbehandlung und für asynchrone
Methodenaufrufe. Ein Delegat kann auf mehrere Funktionen zeigen (Multicast Delegate). Beim Aufruf des Delegaten werden alle an den Delegaten gebundenen Funktionen aufgerufen.
Delegaten kommen in .NET insbesondere zum Einsatz für die Ereignisbehandlung und asynchrone
Methodenaufrufe.
Jeder deklarierte Delegat erhält automatisch die
Methoden Invoke(), BeginInvoke() und EndInvoke().
Delegates in C#
Methodendeklaration :
public string HoleWert(long Parameter)
Deklaration eines Funktionszeigertyps:
public delegate string HoleWertDelegate(long Parameter);
Erstellung eines Zeigers auf die Funktion :
HoleWertDelegate del = new HoleWertDelegate(this.HoleWert);
Visual Basic .NET unterstützt .NET-Funktionszeiger (alias Delegates) durch das Schlüsselwort Delegate.
Methodendeklaration:
Public Function HoleWert(ByVal Parameter As Long) As String
Definition eines Funktionszeigertypen:
Public Delegate Function HoleWertDelegate(ByVal Parameter As Long) As String
Erstellung eines Zeigers auf die Funktion:
Dim del As New HoleWertDelegate(AddressOf Me.HoleWert)
Beispiel 1
[Demo]
public class DelegateBeispiel1
{
// Eigener Delegate
public delegate string Begruessung(string name, string vorname);
static void Run()
{
string e;
// Verwendung eigener Delegate
Begruessung g = Hallo;
e = g("Schwichtenberg", "Holger");
Console.WriteLine€;
g = GutenTag;
e = g("Schwichtenberg", "Holger");
Console.WriteLine€;
// Verwendung vordefinierter Delegate
Action<string> start = Start;
start("test");
Console.ReadLine();
}
// Implementierng #1 Delegate Begruessung<T,T>
static public string Hallo(string name, string vorname)
{
return "Hallo " + vorname + " " + name + "!";
}
// Implementierng #2 Delegate Begruessung<T,T>
static public string GutenTag(string name, string vorname)
{
return "Guten Tag " + vorname + " " + name + "!";
}
// Implementierng Delegate Action<t>
static public void Start(string x)
{
Console.WriteLine("Starte: " + x);
}
}
Beispiel 2
Ein gutes Anwendungsbeispiel für Delegates ist der asynchrone
Methodenaufruf. Für den asynchronen
Methodenaufruf ist neben dem Funktionszeiger auch ein Rückrufroutine (
Callback-Routine) und ein Async
Callback-
Objekt notwendig, das auf die
Callback-Routine verweist und beim Aufruf von BeinInvoke() übergeben werden muss. In der
Callback-Routine kann über EndInvoke() das Ergebnis abgerufen werden.
Public class DelegateBeispiel
{
// === Funktion
public string HoleWert(long Parameter)
{
Console.WriteLine("
Methodenaufruf…");
return "Wert " + Parameter;
}
// === Definition eines Funktionszeigertyps
public delegate string HoleWertDelegate(long Parameter);
// === Hauptprogramm
public void Test()
{
// --- Synchroner Aufruf
Console.WriteLine("Asynchroner Aufruf…");
Console.WriteLine("Ergebnis: " + HoleWert(2));
// --- Asynchroner Aufruf
Console.WriteLine("Asynchroner Aufruf…");
HoleWertDelegate del = new HoleWertDelegate(this.HoleWert);
Async
Callback Callback = new Async
Callback(Fertig);
del.BeginInvoke(123,
Callback, del);
// --- Warten
for (int a = 1; a <= 10; a++)
{
Console.Write("*");
System.Threading.Thread.Sleep(100);
}
Console.ReadLine();
}
// ===
Callback-
Handler
public void Fertig(
IAsyncResult CallbackResult)
{
Console.WriteLine("Aufruf fertig…");
HoleWertDelegate del = (HoleWertDelegate)
CallbackResult.AsyncState;
string Ergebnis = del.EndInvoke(
CallbackResult);
Console.WriteLine("Ergebnis: " + Ergebnis);
}