Поиск…


Синтаксис

  • public delegate TResult Func<in T, out TResult>(T arg)
  • public delegate TResult Func<in T1, in T2, out TResult>(T1 arg1, T2 arg2)
  • public delegate TResult Func<in T1, in T2, in T3, out TResult>(T1 arg1, T2 arg2, T3 arg3)
  • public delegate TResult Func<in T1, in T2, in T3, in T4, out TResult>(T1 arg1, T2 arg2, T3 arg3, T4 arg4)

параметры

параметр подробности
arg или arg1 (первый) параметр метода
arg2 второй параметр метода
arg3 третий параметр метода
arg4 четвертый параметр метода
T или T1 тип (первого) параметра метода
T2 тип второго параметра метода
T3 тип третьего параметра метода
T4 тип четвертого параметра метода
TResult возвращаемый тип метода

Без параметров

В этом примере показано, как создать делегат, который инкапсулирует метод, который возвращает текущее время

static DateTime UTCNow()
{
    return DateTime.UtcNow;
}

static DateTime LocalNow()
{
    return DateTime.Now;
}

static void Main(string[] args)
{
    Func<DateTime> method = UTCNow;
    // method points to the UTCNow method
    // that retuns current UTC time  
    DateTime utcNow = method();

    method = LocalNow;
    // now method points to the LocalNow method
    // that returns local time

    DateTime localNow = method();
}

С несколькими переменными

static int Sum(int a, int b)
{
    return a + b;
}

static int Multiplication(int a, int b)
{
    return a * b;
}

static void Main(string[] args)
{
    Func<int, int, int> method = Sum;
    // method points to the Sum method
    // that retuns 1 int variable and takes 2 int variables  
    int sum = method(1, 1);

    method = Multiplication;
    // now method points to the Multiplication method

    int multiplication = method(1, 1);
}

Лямбда и анонимные методы

Анонимный метод может быть назначен везде, где ожидается делегат:

Func<int, int> square = delegate (int x) { return x * x; }

Лямбда-выражения могут использоваться для выражения того же:

Func<int, int> square = x => x * x;

В любом случае мы теперь можем вызвать метод, хранящийся внутри square следующим образом:

var sq = square.Invoke(2);

Или как сокращение:

var sq = square(2);

Обратите внимание, что для присвоения типа безопасным типа типы параметров и тип возврата анонимного метода должны соответствовать типу типа делегата:

Func<int, int> sum = delegate (int x, int y) { return x + y; } // error
Func<int, int> sum = (x, y) => x + y; // error

Параметры ковариантного и контравариантного типов

Func также поддерживает ковариантные и контравариантные

// Simple hierarchy of classes.
public class Person { }
public class Employee : Person { }

class Program
{
    static Employee FindByTitle(String title)
    {
        // This is a stub for a method that returns
        // an employee that has the specified title.
        return new Employee();
    }

    static void Test()
    {
        // Create an instance of the delegate without using variance.
        Func<String, Employee> findEmployee = FindByTitle;

        // The delegate expects a method to return Person,
        // but you can assign it a method that returns Employee.
        Func<String, Person> findPerson = FindByTitle;

        // You can also assign a delegate 
        // that returns a more derived type 
        // to a delegate that returns a less derived type.
        findPerson = findEmployee;

    }
}


Modified text is an extract of the original Stack Overflow Documentation
Лицензировано согласно CC BY-SA 3.0
Не связан с Stack Overflow