Megosztás a következőn keresztül:


Elnevezett és névtelen metódusokkal rendelkező meghatalmazottak (C# programozási útmutató)

A meghatalmazott hozzárendelhető egy elnevezett metódushoz. Ha egy meghatalmazottat névvel ellátott módszerrel hoz létre, a metódus paraméterként lesz átadva, például:

// Declare a delegate.
delegate void WorkCallback(int x);

// Define a named method.
void DoWork(int k) { /* ... */ }

// Instantiate the delegate using the method as a parameter.
WorkCallback d = obj.DoWork;

Az előző példa egy elnevezett metódust használ. A névvel ellátott metódussal létrehozott meghatalmazottak statikus vagy példánymetódusokat is beágyazhatnak. Az elnevezett metódusok az egyetlen módja a meghatalmazott példányosításának a C# korábbi verzióiban. A C# segítségével példányosíthat egy meghatalmazottat, és azonnal megadhat egy kódblokkot, amelyet a meghatalmazott a meghíváskor feldolgoz. A blokk tartalmazhat lambda kifejezést vagy névtelen metódust, ahogyan az alábbi példában látható:

// Declare a delegate.
delegate void WorkCallback(int x);

// Instantiate the delegate using an anonymous method.
WorkCallback d = (int k) => { /* ... */ };

A delegált paraméterként átadott metódusnak ugyanazzal az aláírással kell rendelkeznie, mint a delegált deklarációnak. A meghatalmazott példányok statikus vagy példánymetódusokat is tartalmazhatnak.

Feljegyzés

Bár a meghatalmazott használhat out paramétert, nem javasoljuk a csoportos küldésű eseménydelegáltak használatát, mert nem tudja, hogy melyik delegált lesz meghívva.

Az egyetlen túlterheléssel rendelkező metóduscsoportok természetes típusú. A fordító ki tudja következtetni a delegált típus visszatérési típusát és paramétertípusát:

var read = Console.Read; // Just one overload; Func<int> inferred
var write = Console.Write; // ERROR: Multiple overloads, can't choose

Példák

Az alábbi példa egy egyszerű példa a meghatalmazott deklarálására és használatára. Figyelje meg, MultiplyCallbackhogy a meghatalmazott és a társított metódus MultiplyNumbersis ugyanazzal az aláírással rendelkezik

// Declare a delegate
delegate void MultiplyCallback(int i, double j);

class MathClass
{
    static void Main()
    {
        MathClass m = new MathClass();

        // Delegate instantiation using "MultiplyNumbers"
        MultiplyCallback d = m.MultiplyNumbers;

        // Invoke the delegate object.
        Console.WriteLine("Invoking the delegate using 'MultiplyNumbers':");
        for (int i = 1; i <= 5; i++)
        {
            d(i, 2);
        }

        // Keep the console window open in debug mode.
        Console.WriteLine("Press any key to exit.");
        Console.ReadKey();
    }

    // Declare the associated method.
    void MultiplyNumbers(int m, double n)
    {
        Console.Write(m * n + " ");
    }
}
/* Output:
    Invoking the delegate using 'MultiplyNumbers':
    2 4 6 8 10
*/

Az alábbi példában egy meghatalmazott statikus és példánymetegrálási módszerekre is megfeleltet, és mindegyikből adott információkat ad vissza.

// Declare a delegate
delegate void Callback();

class SampleClass
{
    public void InstanceMethod()
    {
        Console.WriteLine("A message from the instance method.");
    }

    static public void StaticMethod()
    {
        Console.WriteLine("A message from the static method.");
    }
}

class TestSampleClass
{
    static void Main()
    {
        var sc = new SampleClass();

        // Map the delegate to the instance method:
        Callback d = sc.InstanceMethod;
        d();

        // Map to the static method:
        d = SampleClass.StaticMethod;
        d();
    }
}
/* Output:
    A message from the instance method.
    A message from the static method.
*/

Lásd még